اللهم صلى وسلم على سيدنا محمد و على آله وصحبه أجمعين 
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" أقرا باسم ريك الذي خلق » خلق كلإنسان من علق ء 


أقرا وربك الأكرم الذي علم بالقلم علم الإكيان مالم يعلم " 


برامج بلغة سي بلس بلس 


C++ 


Engineer: Khaled yassin alsheikh 
إعداد المهندس خالد ياسين الشيخ‎ 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله جاسي اشح khaledyassinkh @gmail.com‏ 


برامج بلغة ++ (الجزء الثاني) 
جمیع sاںماںہ‏ من الیسار للیمین programs in c++‏ 
الخرج: في حال أدخلنا ووم هو: #include<iostream.h>‏ 
#include<conio.h>‏ 
void p(char * a){ a. password correct‏ 
int i=0; pass‏ 
while(i<4)‏ 
cout<<a[i++]; Kk‏ 


cout<<endl; password correct 
pass 


main (){ FoR KF 


int s=0; error please enter new password 
char x[]="pass" , pass[4]; 
for(;;){ E 
for(int i=0;i<4;i++){ password correct 
pass[i]=getch(); 
cout<<'*'; الجواب الصحيح يختلف عما سبق .ع‎ 
for(i=0;i<4;i++){ 
if (pass[i]==Xx[i]) s++; ملاحظة: التابع عع تقوم بقراءة المحرف دون إظهار المحرف المدخل‎ 
else ولذلك یجب تضمین هذہ‎ conio.h على الشاشة و التابع موجود في المكتبة‎ 
break; المكتبة قبل استخدام هذا التابع‎ 
} و في حال أردت إظهار المحرف المدخل على الشاشة استخدم التابع‎ 
if (s==4){ getche() 
cout<<"\npassword 
correct"<<endl; 
break; 
1 
cout<<endl; 
cout<<"error please enter new 
password"<<endl; 
s=0; 
} 


p(pass); 
getch(); 
return O; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


الخرج: 
يتم طباعة ۲41٥‏ هأ٣لك‏ بشكل لا نهائي لأن البرنامج يدخل في حلقة 
لا نهائية. لأن حلقة ۲ه لا نهائية. 


بلغ عدد سكان الجمهوية العربية السورية عام 1980 حوالي 12 مليون نسمة 
و إذا علمت أن معدل تزايد السكان السنوي يبلغ حوالي 2.3% تقريبا و 
المطلوب كتابة برنامج بلغة ++ يقوم بمايلي: 

© 

لكي يتضاعف عدد السكان حيث يتم طباعة 

السنة ٣‏ همر التي يتضاعف فيها عدد السكان. 
عدد السنوات. 
عدد السكان حينها. 


الخرج: 


year =2011 
number of years =31 
number of population =24284316.874 


اكتب إجرائية ه۴ بلغة ++ع يمرر إليها عدد حقيقي بفاصلة و تقوم 


ويراد الحل بدون استخدام أي تابع جاهز. 


مثال: 

تم تمرير العدد 33.3 يتم طباعة 333/10 
تم تمرير العدد 22.4 يتم طباعة 112/5 
تم تمرير العدد 0.5 يتم طباعة 1/2 

تم تمرير العدد 0.25 يتم طباعة 1/4 

تم تمرير 4.125 يتم طباعة 33/8 

تم تمرير 50.2 يتم طباعة 251/5 


۾ خلګ الائ 


إجراء ٥٣‏ امهم يقوم بحساب و طباعة عدد سنوات اللازمة 


khaledyassinkh @gmail.com 
#include<iostream.h> 
#include<ctype.h> 
void main(){ 
while (true){ 
for(;;) 
cout<<"syria arabic"<<endl; 
if(1) 
break; 


} 


#include<iostream.h> 


#include <iomanip.h> 
void population(double n){ 
double temp=n; 
long year=1980, i=0; 
while(n<2*temp){ 
A= * 1.023; 
year++; 
i++; 
} 
cout<<"year ="<<year<<endl; 
cout<<"number of years 
="<<i<<endl; 
cout<<"number of population 
="<<setprecision(11)<<n<<endl; 
} 
void main(){ 
double n=12000000; 
population(n); 


#include<iostream.h> 
#include<stdio.h> 
void f(double & n){ 
HER Z2 
} 
void frac(double n1){ 
double n2,n3,m; 
MARL 
Int ZAL 
n2=n1-t;jint i=1; 
while(n2!=0){ 
i++; 
ALERT 
ERM, 
n2=n1-t; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل بسي اشح khaledyassinkh @gmail.com‏ 
if(n2!=0)‏ 
}=1 

} 

cout<<n1<<"/"<<i<<endl;; 
} 
void main(){ 

double n1; 

cin>>n1; 

frac(n1); 


#include<iostream.h> 
#include<conio.h> 
int countcall(void){ 
static int count=0; 
count++; 
return (count); 
} 
main(){ 
cout<<countcall()<<","; 
cout<<countcall()<<","; 
cout<<countcall()<<endl; 


#include<iostream.h> 
int main(){ . syria 
inixë5; . welcome to syria 
if(x>5) . sYyriawelcome to syria 
if(x%2==1) . لا يتم طباعة أي شىء‎ 
cout<<"syria"; . الجواب الصحيح يختلف عما سبق‎ 
else 
cout<<"welcome to syria"; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خل جاسي اشح‎ 
#include<iostream.h> الخرج:‎ 
#include<conio.h> 
char *f1(int); 
char *f2(int); 
char *f1(int generations){ 
if(generations==0) لأحظ عة الاأستتغاغات؟؟‎ 
return ("f1"); ی‎ 
else 
return(f2(generations-1)); 
} 
char *f2(int generations){ 
if(generations==0) 
return ("f2"); 
else 
return (f1(generations-1)); 
} 
void main(){ 
cout<<f1(5)<<endl; 
cout<<f1(5+5)<<endl; 
cout<<f2(10)<<endl; 
cout<<f1(6)<<endl; 
} 


#include<iostream.h> 


#define sqr(n) n*n a. 19.36.81‏ 
main(){ b. 16.36,81‏ 
ERE, ¢. 16.116,16‏ 
MEE; d. 18.32/41‏ 
الخرّات الضحح بختلف غماشسق. ٠ة cout<<sqr(m)<<endl;‏ 
ملاحظة: الماكرو يشبه التابع مع بعض الاختلافات ويمتاز الماكرو عن التابع 
بالسرعة و سهولة في كتابته و استخدامه أنواع مختلفة من المعطيات دون 
تحديد المعطيات في ترويسته. 


#include<iostream.h> 

#include<math.h> 

main(){ 
int a=100,b(2),c=20,d=30,e=1,f=128; 
c=sqrt(int(a/b)*3); 
d=fmod(a/pow(b,2),4); 
e=ceil(c/b*0.2); 
f=floor(((arb+c+d)*2)/2); 
Coli" E lS "tééé<SeRdI: 
cout<<"d is: "<<d<<endl; 
cout<<"e is: "<<e<<endl; 
cout<<"f is: "<<f<<endl; 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


الخرج: 


سبحانك رينا لا علم لنا إلا ما علمتنا 


syria 

welcome to syria 
welcome to syria 
good luck 

I'm From syria 
syria- damascus 
information 

I'm From syria 
syria- damascus 
information 
syria- damascus 
information 
information 


Ox00428D50 
Ox00428D50 


۾ خالك الاثي 


khaledyassinkh @gmail.com 


#include<iostream.h> 
main(void){ 
int s=1; 
do{ 
switch (s){ 
case 1:cout<<"syria"<<endl; 
case 2: cout<<"welcome to 
syria"<<endl;break; 
case 3:cout<<"good luck"<<endl; 
case 4:cout<<"I'm From syria"<<endl; 
case 5:cout<<"syria- damascus "<<endl; 
default:cout<<"information"<<endl; 
} 
S++; 
} 
while(s<7); 
1 
#include<iostream.h> 
#include<conio.h> 
IRE X100; 
int & f1(){ 
return X; 
} 


void main(){ 


f1()=x; 
f1()-=10; 
XH+; 
cout<<x<<endl; 
cout<<f1(); 
getch(); 
ل‎ 
#include<iostream.h> 
#include<conio.h> 
int x=100; 
int & f1(){ 
return X; 
} 


void main(){ 


f1()=x; 
f1()-=10; 
XH+; 
cout<<&x<<endl; 
cout<<&f1()<<endl; 


getch(); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خل بسي اشح‎ 
#include<iostream.h> الخرج:‎ 
#include<conio.h> 
int x=100; 
int *p=&x; 
int * f1(){ 

return Pp; 


} 


void main(){ 
10-2; 


XH+; 
*p+=1; 
cout<<x<<endl; 
cout<<*f1()<<endl; 
cout<<*p<<endl; 
getch(); 

} 

#include<iostream.h> 

#include<conio.h> 

int x=100; Ox00428D50 

int *p=&x; Ox00428D50 

int * f1(){ Ox00428D50 
return p; 

} 

void main(){ 
TIOS2: 
XH+; 
*p+=1; 
cout<<&x<<endl; 
cout<<f1()<<endl; 
cout<<p<<endl; 
getch(); 

} 

#include<iostream.h> 

#include<conio.h> Ox00428D50 

int x=100; Ox00428D50 

int *p=&x; 4 

int * f1(){ 4 

return pj; 

} 

void main(){ 
T1052; 
XH+; 

pej 

cout<<&x<<endl; 
cout<<f1()<<endl; 
cout<<*p<<endl; 


cout<<*p<<endl; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


getch(); 


#include <iostream.h> 
template< class T > Array a contains: 
void printArray( const T *array, const int 12345 
count ) Array b contains: 
1 1.1 2.2 3.3 4.4 5.5 6.6 7.7 
for (inti = 0; i < count; i++ ) Array c contains: 
cout << array[ i ] << " "; HELLO To SYRIA 


cout << endl; 


int main() 
{ 

const int aCount = 5, bCount = 7, cCount = 
15; 


ital aCount |= [L230 

double b[ BEoUnt J] ={ L1 2.2, 3.344, 55, 
6.6, 7.7}; 

CRaF ê] CCoOURNE] =" HELLO TOSVYRIA"; 

cout << "Array a contains:" << endl; 


printArray( a, aCount ); 

cout << "Array b contains:" << endl; 
printArray( b, bCount ); 

cout << "Array c contains:" << endl; 
printArray( c, cCount ); 

return O; 


#include<iostream.h> 
int main(void){ the address of a isOx0012FF7C 
int a; 
int *p; the contents stored in p isOxO0012FF7C 
a57; 
p=&a; the stored in a is7 


cout<<"the address of a is"<<&a<<"\n\nthe the value to which p pointer is7 

contents stored in p is"<<p; و يمكن تمتيل ذلك بالذاكرة الرئيسية كما يلي:‎ 
cout<<"\n\nthe stored in a is"<<a<<"\n\nthe 
value to which p pointer is"<<*p<<endl; 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


Memory address Variable a(7)-integer is 4 bytes 


OxOO012FF7C OOO0O000OO 00000000 00000000 00000111 


الخرج: 


Assalamu Alaikum 


فائدة(التوابع السطریۂ) ٥۸‏ ااءہں؟ ٥ہ‏ اہ و الفرق یبینھا وبين ہ0ااcمںf‏ 
التوابع العادية 


لدينا التابع التالي: 
int sqr(int x){‏ 
return (x*X);‏ 
} 


حيث عمل هذا التابع هو أنه يعطينا مربع عدد مدخل و في التابع الرئيسي 
نستطيع أن نكتب هذا الاستدعاء وفي كل مرة يتم التعريف التابع على أنه 
م"اہ يقوم المترجم باستبدال التابع بالتابع نفسه. 

int x=sqr(10); 


قيمة × هي ٠٠١=٠٠*٠١‏ لنتخيل أننا استخدمنا التابع السابق لتربيع ٠٠٠١‏ 
رقم في حلفة ۴٥۲‏ مثلا و في كل مرة يصل المترجم إلى تنفيذ التابع يتم 
استدعاء التابع و تنفيذ ما بداخله ثم إرجاع القيمة إلى المتحول × 


و لكن في هذه الحالة نذهب ثم نعود للتابع الرئيسي 200 مثلا وهذا يأخذ 
الوقت 


inline int sqr(int x){ 
return (x*x); 


} 


يمكنك استدعاء التابع تماما كما فعلنا في المرة السابقةء و لكن هذه المرة عند 


۾ خلګ الائ 


khaledyassinkh @gmail.com 
return O; 


} 


#include<iostream.h> 
void main(){ 
İi =2 K=5, * pS: 
*p=3; 
1K 
while(i!=0){ 
İf(i %2==0) 
cout<<"Assalamu 
Alaikum"<<endl; 
1 
1 
#include<iostream.h> 
inline Double(int); 
void main(){ 
int target=6; 
target=Double(target); 
cout<<"Target="<<target<<endl; 
target=Double(target); 
cout<<"Target="<<target<<endl; 
target=Double(target); 
cout<<"Target="<<target<<endl; 


inline Double(int target){ 
int result; 
result=2*target; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جي اشح khaledyassinkh @gmail.com‏ 
استدعاءِ التابع سيقوم المترجم خلال عملية الترجمة بالتالي: 


int=x*x; 


سيتم استبدال التابع ووضع »×*× مباشرة و بالتالي لم يعد هناك ذهاب و عودة 
إلى التابع 


الخرج: 


Target=12 
Target=24 
Target=48 
ملاحظة هامة:‎ 


ينصح استخدام التوابع السطرية فقط مع التوابع الصغيرة . 


التوابع السطرية تزيد من سرعة التنفيذ في حال التوابع الصغيرة. 


#include<iostream.h> الخرج:‎ 
#include<iomanip.h> 
inline int sqr(int n){ 
return n*n; 
} 
void main(){ 
for(int i=1;i<=10;i++) 
cout<<i<<setw(4)<<sqr(i)<<endl; 


1 
2 
3 
4 
5 
6 
7 
8 
9 


سلسلة فيبونlشي #include<iostream.h> :(FibonacCi series)‏ 
هي سلسلة من الأرقام حيث أنه أي رقم في هذه السلسلة يساوي مجموع void Fibonacci(int n){‏ 
الرقمين السابقين له و يكون الرقم الأول من السلسلة و الثاني منها يساوي int a=1,6=a;‏ 
الواحد ;" cout<<a<<" "<<b<<"‏ 
مثال: for(int i=3;i<=n;ji++){‏ 
int s=a+b; 1123 5 813 214‏ 
و المطلوب كتابة برنامج بشكل تكراري يقوم بإيجاد عناصر سلسلة فيبوناشي ;" cout<<s<<"‏ 
من أجل " عنصر . a=b;‏ 
b=s;‏ 
1 
cout<<endl;‏ 
} 
void main(){‏ 
int n=9;‏ 
Fibonacci(n);‏ 


۾. خاک الالح اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خله جاسي اشح‎ 
#include<iostream.h> اكتب بلغة ++ برنامج يقوم بفرز نسق وطباعته.‎ 
sort(int v[],int n){ 
int i,j; چ‎ 
for(i=0;i<n;i=i+1) 
for(j=i-1;j>=0&&v[j]>v[j+1];j=j-1) 
{ 
int t=v[j]; 
vljl=v[j+1]; 
v[j+1]=t; 
} 
print(int a[],int n){ 
int i=0; 
while(i<n) 
cout<<a[i++]; 
cout<<endl; 


} 


void main(){ 
int a[5]={5,4,3,2,1}; 
print(a,5); 
sort(a,5); 
print(a,5); 


1 
#include<iostream.h> اكتب برنامج يعمل على قراءة م قيمة صحيحة تم يحسب الوسط الحسابي و‎ 
#include<math.h> الانحراف المعياري لهذه القيم باستخدام الأنساق.‎ 
int sqr(int n){ 
return n*n;} 
void main(){ 
CORSTIRT HED; 
int *mat=new int[n]; 
int i,sum=0; 
double val=0,avr,s; 
for(i=0;i<n;i++){ 
cout<<"enter the value "<<i+1<<endl; 
cin>>mat[i]; 
sum+=mat[i]; 
1 
avr=(float)sum/n; 
for(i=0;i<n;i++) 
val+=sqr(mat[i]-avr); 
s=sqrt(val/n); 
cout<<"average="<<avr<<endl; 
cout<<"S="<<s<<endl; 
delete[]mat; 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,ال الم مې . خا جسې لايح 
-١‏ اكتب بلغة ++ تابع إل" اأ" يعيد أصغر عنصر في المصفوفة(نسق). 
۲- اكتب بلغة ++ تابع .»هم يعيد أكبر عنصر في المصفوفة(نسق). 
الخرج: 
8.2 
1.5 


khaledyassinkh @gmail.com 


#include<iostream.h> 
#include<conio.h> 


double min(double *mat,int n) 
int i=0; 
double s=*(mat+i); 
for( i=1;ji<nji++) 
if(mat[i]<s) 
s=mat[i]; 
return s; 
return -1; 


} 


double max(double *mat,int n) 
{ 
int i=0; 
double s=*(mat+i); 
for( i=1;ji<n;ji++) 
if(mat[i]>s) 
s=mat[i]; 
FETS, 
return -1; 
} 
#define n 10 
int main(void){ 
double 
mat[n]={5,8,6,2,2.5,1.5,7,7.9,8.2,1.9}; 
cout<<max(mat,n)<<endl; 
cout<<min(mat,n)<<endl; 
return O; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله بسي اشح khaledyassinkh @gmail.com‏ 
المطلوب:برنامج يقوم بضرب مصفوفتين حيث : #include<iostream.h>‏ 
لدينا مصفوفتين ثنائية البعد المصفوفة ۸ تحوي م سطر و " عمودو #include<iomanip.h>‏ 
المصفوفة 8 تحوي ») عامود و " سطر لأن شرط الضرب يجب أن يكون const int n=10;‏ 

محققاً و بالتالي فان عدد أعمدة المصفوفة ۸ و أسطر المصفوفة 8 متساوي. const int m=8;‏ 

اكتب إجرائية ام تقوم بعملية الضرب ووضع الناتج في مصفوفة ثالثة °. const int k=12;‏ 

void mult(int A[][m],int B[][k],int 
CI[kK])K{ 


for(int i=0;i<n;ji++) 
for(int j=0;j<k;j++){ 
C[il[j]=0; 
for(int 
1=0;jl<m;l++) 


C[iJ[i]+=A[i1[j]*B[IÛJ; 
} 
1 
void read1(int a[][m]){ 
for(int i=0;i<n;i++) 
for(int j=0;j<m;j++){ 


cout<<"A["<<i<<"]"<<"["<<j<<"]"; 
cin>>a[i]]; 
1 
1 
void read2(int b[][k]){ 
for(int i=0;i<n;ji++) 
for(int j=0;j<k;j++){ 


cout<<"B["<<i<<"]"<<"["<<j<<"]"; 
cin>>b[i][j];} 
ا‎ 
void print(int C[][k]){ 
for(int i=0;i<n;i++){ 
for(int j=0;j<k;j++) 


cout<<setw(4)<<C[i][j]<<setw(4); 
cout<<endl; 


} 


void main(){ 
int A[n][m]; 
int B[m][k]; 
iMECIAnIIKI; 
read1(A); 
read2(B); 
mult(A,B,C); 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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print(C);‏ 


اکتب برنامج يعمل من خلال سجل على إدخال بيانات تتعلق ب " شخص و #include<iostream.h>‏ 
يحوي السجل الاسم الأول ع" هم و الاسم الأخير ع٠۳‏ هم| و العمر عمعج . struct pers{‏ 
و تخزين هذه البيانات في مصفوفة هص تم يرتب هذه البيانات ترتيبا char fname[20];‏ 
تصاعديا و في حال تساوي الاسم الأول يفحص الكنية. ثم يقوم البرنامج char Iname[20];‏ 
بطباعة البيانات قبل وبعد الفرز. int age;‏ 
1 
void insertdata(pers mat[],int n){‏ 
for(int i=0;i<n;ji++){‏ 
cin>>mat[i].fname;‏ 
cin>>mat[i].lIname;‏ 
cin>>mat[i].age;‏ 


} 
} 


void swap(pers mat[],int i,int j){ 
pers t=mat[i]; 
mat[i]=mat[j]; 
matlj]=t; 

} 

void sortdata(pers mat[],int n){ 
for(int i=0;i<n-1;i++) 

for(int j=0;j<n-1;j++) 


if(mat[j].fname>mat[j+1].fname) 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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swap(mat,j,j+1);‏ 
else‏ 


if(mat([j].fname==mat[j+1].fname){ 
if(mat[j].lIname>mat[j+1].Iname) 


swap(mat,j,j+1);} 
} 
void print(pers mat[],int n){ 
for(int i=0;i<n;ji++) 
cout<<mat[i].fname<<" 
"<<mat[i].lname<<" "<<mat[i].age<<endl; 


} 


void main(){ 
int fM; 
cout<<"enter size array "; 
cin>>n; 
pers * mat=new pers[n]; 
insertdata(mat,n); 
cout<<" "<<endl; 
print(mat,n); 
cout<<" "<<endl; 
sortdata(mat,n); 
print(mat,n); 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 
المطلوب كتابة بلغة C++‏ برنامج يقوم بتعريف مصفوفة من الأعداد #include<iostream.h>‏ 
الصحيحة تحوي ۲ سطر و ع عمود . #include<iomanip.h>‏ 
كتابة إجرائية اذم لطباعة المصفوفة بطريقة مرتبة (صفوف const int r=3,c=4;‏ 
و أعمدة) void print(int a[][c])4‏ 
كتابة W‏ ٥۲٥ء٣٠۷٠‏ لطباعة بترتيب عكسي للصفوف for(int i=0;ji<r;i++){‏ 
كتابة ٣نامع‏ لطباعة کل عمود بسطر. for(int j=0;j<c;j++)‏ 
كتابة إجرائية ٠W‏ ٣ء‏ لطباعة مجموع كل صف. cout<<a[i][j]<<setw(4);‏ 
كتابة إجرائية ١"ںامع‏ مء لطباعة مجموع كل عمود. cout<<endl;‏ 
كتابة إجرائية ١"ںاهء×ه‏ م لطباعة العنصر الأكبر من كل } 
عمود 
كتابة إجرائية ٣٥W‏ ×ه م لطباعة العنصر الأكبر من كل صف void reverserow(int a[][c]){‏ 
تابع ١۳ء‏ يعيد مجموع عناصر المصفوفة ككل. for(int i=0;i<r;i++){‏ 
for(int j=c-1;j>=0;j--)‏ 


cout<<a[i][j]<s<setw(4); 
cout<<endl; 
1 
} 
void columnl(int a[][c]){ 
for(int j=0;j<c;j++){ 
for(int i=0;i<r;ji++) 


cout<<a[i][j]<s<setw(4); 
cout<<endl; 
} 
} 
void sumrow(int a[][c]){ 
int sum; 
for(int i=0;i<r;ji++){ 
sum=0; 
for(int j=0;j<c;j++) 
sum+=a[i][j]; 


cout<<"row"<<i+1<<"="<<sUum; 


cout<<endl; 


} 
} 
void sumcolumnl(int a[][c]){ 
int sum; 
for(int j=0;j<c;j++){ 
sum=0; 
for(int i=0;i<r;ji++) 
sum+=a[i][j]; 
cout<<"column"<<j+1<<"="<<sum; 
cout<<endl; 


} 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


۾. خالك الاثي 
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void maxcolumnl(int a[][c]){ 
int max; 
for(int j=0;j<c;j++){ 
max=a[0][i]; 
for(int i=1;i<rji++) 
if (a[i][j]>max) 
max=a[i][j]; 


cout<<"maxcolumn"<<j+1<<"="<<max 


cout<<endl; 


} 
} 
void maxrow(int a[] [c]){ 
int max; 
for(int i=0;i<r;ji++){ 
max=a[i][0]; 
for(int j=1;j<c;j++) 
if(a[i][j]>max) 
max=a[i][j]; 


cout<<"maxrow"<<i+1<<"="<<max; 
cout<<endl; 
} 
} 
int summat(int a[][c]){ 
int sum=0; 
for(int i=0;i<r;ji++) 
for(int j=0;j<c;j++) 
sum+=a[i][j]; 
return sum; 


void main(){ 
int a[r][c]={1,2,3,4, 
5,6,78, 
9,10,11,12}; 
print(a); 
cout<<endl; 
reverserow(a); 
cout<<endl; 
column(a); 
sumrow(a); 
sumcolumn (a); 
cout<<endl; 
maxcolumn(a); 
cout<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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۾ خالك الاثي 
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maxrow(a); 
cout<<endl; 
cout<<"sum items all 
array="<<summat(a)<<endl; 


#include<iostream.h> 
#include<iomanip.h> 
void main(){ 
int j;Š=0; 
int mat[][3]={1;2;3, 
4,5,6, 
7,8,9}; 
for(int i=0;i<3;i++) 
for( j=0;j<3;jj++) 
(i ==0| [I52 ) 
cout<<mat[i][j]<<" "; 


} 

#include<iostream.h> 

char * f1(char *syria,int n,int a[]){ 
cout<<*syria<<endl; 
cout<<syria<<endl; 
cout<<syria[a[n]]<s<endl; 
return syria; 


} 


void main(){ 
char *s="arabic"; 
int a[9]={1,3,4}; 
s=f1(s,4,a); 
cout<<s<<endl; 

} 

#include<iostream.h> 

int max=4; 

int *p=8&max; 

int &f1(int n){ 
max=max+n/2*3+4; 
return max; 

} 

int *f2(int n){ 
*p=*p+n/2+4; 
return pj; 

} 

void main(){ 
f1(max); 
f2(max); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


cout<<max<<endl; 
cout<<*p<<endl; 


المطلوب:كتابة برنامج يعمل على قراءة مصفوفة مربعة يحدد بعدها #include<iostream.h>‏ 
المستخدم ثم يحسب هذا البرنامج: #include<iomanip.h>‏ 
-١‏ مجموع عناصر کل سطر(تابع 1م). void read(int *a,int n){‏ 
مجموع عناصر کل عامود(تابع 2م). for(int i=0;i<n;i++)‏ 
مجموع كل العناصر(تابع 3م). for(int j=0;j<n;j++){‏ 
وار اسر الفط الر ي( ج p4‏ 
مجموع عناصر القطر الثانوي(تابع 5م). cote cic SEE‏ 
-٦‏ إجرائيات الطباعة المناسبة. CIR>> * (aR i}‏ 
ملاحظة: المطلوب تحقيق جميع ما سبق باستخدام المؤشرات } 
حصراً. void print(int *a,int n){‏ 
for(int i=0;i<n;i++)‏ 
{ 


for(int j=0;j<n;jj++) 


cout<<*(a+n*i+j)<<setw(4); 
cout<<endl; 
ل‎ 
} 
void printarrangement(int suml[],int 
sumc[],int n){ 
for(int i=0;i<n;i++){ 


cout<<"line"<<i+1<<"summery="<<su 
mI[i]<s<endl; 


cout<<"column"<<i+1<<"summery="< 
<sumc[i]<s<endl; 


} 
} 


void p1(int *a,int n,int suml[]){ 
for(int i=0;i<n;ji++) 
{ 
suml[i]=0; 
for(int j=0;j<n;jj++) 
suml[i]+=*(a+n*i+j); 


} 
void p2(int*a,int n,int sumc[]){ 
for(int j=0;j<n;jj++){ 
sumc[j]=0; 
for(int i=0;i<n;ji++) 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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sumc[j]+=*(a+n*i+j); 
} 
int p3(int suml[],int n ){ 
int sumt=0; 
for(int i=0;i<n;ji++) 
sumt+=suml[i]; 
return sumt; 
} 
int p4(int *a,int n){ 
int sumd=0; 
for(int i=0;i<n;ji++) 
sumd+=*(a+n*i+i); 
return sumd; 
} 
int p5(int *a,int n){ 
int sumd=0; 
for(int i=n;i>O0;i--) 
sumd+=*(a+n*(n-i)+(i-1)); 
return sumd; 


} 


void main(){ 
cout<<"enter "<<endl; 
int n; 
cin>>n; 
int *suml=new int[n]; 
int* sumc=new int[n]; 
ME a; 
a=new int *[n]; 
for(int i=0;ji<n;i++) 
a[ij=new int [n]; 
read(&a[0][0],n); 
p1(&a[0][0],n,suml); 
p2(&a[0][0],n,sumc); 
p3(suml,n); 
print(&a[0][0],n); 
cout<<p3(suml,n)<<endl; 
printarrangement(suml,sumc,n); 
cout<<p4(&a[0][0],n)<<endl; 
cout<<p5(&a[0][0],n)<<endl; 
delete []sumc; 
delete []suml; 
for (i=0;i<n;ji++) 
delete []a[i]; 
delete []a; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


اكتب برنامج بلغة ++ يعرف نسق يحوي ١‏ عنصر و المطلوب: 
1 - إجراء لتعبئة عناصر النسق. 
3- إجراء لطباعة عناصر النسق. 


ملاحظة هامة' ما الفرق بين الإجراء sumprev‏ و الإجراء إلاك. 


اكتب إجراء يقوم بحساب وطباعة قواسم عدد ما عدا العدد نفسه عن 
طريق سق حيث يطلب تخزين هذه القواسم في نسق ثم طباعة 
الق ام حلي شاف الخانف 

مثال: قواسم العدد 6 هي ,1,2,3 

قواسم العدد 18 هي ,1,2,3,6,9 

قواسم العدد 13 هي 1 

قواسم العدد 100 هي 1,2,4,5,10,20,25,50 


khaledyassinkh @gmail.com 
#include<iostream.h> 
void readmat(int *mat,int n){ 
for(int i=0;i<n;ji++) 
{ 
cout<<"mat["<<i<<"]= "; 
cin>>*(matri); 
} 
1 
void print(int mat[],int n){ 
int i=0; 
for(ji<n;i++) 
cout<<*(mat+i)<<","; 
cout<<endl; 
} 
void sumprev(int mat[],int n){ 
for(int i=1;i<n;ji++) 
mat[i]+=mat[i-1]; 
} 
void sum(int mat[],int temp[],int n){ 
for(int i=0;i<n;ji++) 
temp[i]=mat[i]; 
for(i=1;i<n;ji++) 
mat[i]+=temp [i-1]; 
ا‎ 


void main(){ 
const n=5; 
int mat[n],temp[n]; 
readmat(mat,n); 
print(mat,n); 
sum(mat,temp,n); 
print(mat,n); 
sumprev(temp,n); 
print(temp,n); 

} 

#include<iostream.h> 

void divider(int mat[],int n,int &count){ 

COURNtZO]; 

for(int i=1;ji<=n/2;i++) 

if(n%i==0){ 

mat[count]=i; 

count++; 

} 

} 

void print(int mat[],int n){ 
int i=0; 
for(ji<n;i++) 

cout<<*(mat+i)<<","; 

cout<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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} 


void main(){ 
const max=200; 
int mat[max];jint c,n; 
cin>>n; 
divider(mat,n,c); 
print(mat,c); 
1 2 
#include<iostream.h> ثم يختبرها إذا كانت‎ N*١N اكتب برنامجا يقرأ عناصر مصفوفة مربعة‎ 
#include<math.h> ذات قطر مسيطر أم لا.‎ 
void readmat(int *mat,int n){ ملاحظة : تكون المصفوفة ذات قطر مسيطر إذا كانت القيمة المطلقة لكل‎ 
for (int i=0; i<n;i++) عنصر في القطر الرئيسي أكبر من مجموع القيم المطلقة للعناصر الموجودة‎ 
for (int j=0; j<n;j++){ معه في نفس السطر.‎ 
المصفوفة التالية ذات قطر مسيطر:‎ 
couté<" mat é<is<" E" "<< <<"; 
cin>>*(mat+i*n+j); 
} المصفوفة التالية ذات قطر مسيطر‎ 
bool dominant(int *mat,int n){ 
int Sum =0; 
for (int i=0; i < n; i++) { 
for (int j=0; j < n; j++) 
if )¡ (ز=!‎ 
Sum += abs(*(mat+i*n+j)); 
if (abs(*(mat+i*n+i))<=Sum) 
return false; 
SUM =O; 
} 
return 1; 
} 
void print(int *mat,int n){ 
for(int i=0;i<n;ji++){ 
for(int j=0;j<n;jj++) 
cout<<*(mat+ti*n+j)<< 
cout<<endl; 


Hi 
£ 


} 
} 
void main(){ 
const n=3; 
int mat[n][n]; 
readmat(&mat[0][0],n); 
print(&mat[0][0],n); 
if((dominant(&mat[0][0],n))==true) 
cout<<"The Array is 
dominant" <<endl; 
else 
cout <<"The Array is not 
dominant" << endl; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل بسي اشح khaledyassinkh @gmail.com‏ 


أكتب برنامج يقرا نص باللغة الإنكليزية و يحسب طول النص علما أن #include <iostream.h>‏ 
النص ينتهي بنقطة (.) ثم يحسب عدد كل من الأحرف الصغيرة و ;400 = const int max‏ 
الكبيرة و الأوقام و الرموز الاخرى... void main()‏ 
ملاحظة : سنرمز للحروف الكبيرة ب عع۲ه| { 
و نرمز للحروف الصغيرة ب ااجة"٣ء int y, large = 0, small = 0, number =0, other=0;‏ 
و نرمز للأرقام ب char Mat[max]; "u be۲‏ 
و نرمز للرموز الأخرى ب عام cin >> Mat[0];‏ 
int i=0;‏ 
while ( (Mat[i] != '.') && (i < max) ) {‏ 
y = Matli];‏ 
if ( (y >= 65) && (y <= 90) )‏ 
large+t;‏ 
else if ( (y >= 97) && (y <= 122) )‏ 
small++;‏ 
else‏ 
if (y>='0' &&y<='9'(‏ 
number++;‏ 
else‏ 
other++;‏ 


cin >> Mat[++i]; 

} 

cout << "large count = " << large<< endl; 

cout << "small count = " << small << endl; 

cout << "number count = " << number << 

endl; 

cout << "other count = " << other << endl; 

} 

اكتب برنامج بلغة ++ يقرأ سسلسلة من الحروف ثم يقوم بطباعتها بشكل #include<iostream.h>‏ 

معكوس علما أن السلسلة تنتهي بنقطة (.). void main(){‏ 

مثال تم إدخال ."ووه تطبع على الشاشة رهءوام char mat[400];‏ 

تم إدخال .ااج "٨ه‏ تطبع على الشاشة ٥۳ه٣اها int i=O;‏ 

cin>>mat[0]; 

while(mat[i]!=".'){ 
cin>>mat[++i]; 

} 

int s=i; 

for(int j=i-1;j>=0;j--) 

cout<<mat[j]; 

cout<<endl; 


} 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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اكتب بلغة ++ تابع أ0 ه۲ | لحساب القيمة التقريبية لجذر #include<iostream.h>‏ 
تربيعي لعدد حقيقي عندمايصبح القيمة التقريبية للجذر هي 1%. float findroot(float value){‏ 
مثال 4=ھں اھ۷ یرد التابع 1.99939 float testval=1,‏ 
e-0‏ uıا۷a‏ یرد التابع 9.96753 fesl;‏ 
5-ueاa/‏ يرد التابع 3.87133 deviation,‏ 
09ع ںاج۷ يرد التابع 10.0113 و هكذا دوالبك | 11 normdey}‏ 


res1=value/testval; 
deviation=res1-testval; 
testval=testval+(deviation/2); 
normdev=(deviation/res1); 
} 
while((normdev>0.01) | |(normdev<- 
0.01)); 
return res1; 
1 
void main(){ 
float n; 
cin>>n; 
cout<<findroot(n)<<endl; 
} 
int complication(int n){ اكتب تابع ۸٥اهءاامصهء بلغة ++ يقوم بحساب و تدوير عدد‎ 
if(N%2==0) ۲ إلى عدد من مضاعفات‎ 
return n; اكتب إجرائية "آ٣م تقوم بطباعة تقريب جميع الأعداد إلى‎ 
else مضاعفات ۲ ضمن المجال المغلق [«..1] (مستفيدا من الطلب‎ 
return n+(2-n%2); الأول)‎ 
} 
void print(int n){ 
for(int i=1;ji<=n;ji++) 
cout<<complication (i)<<endl; 


} 
void main(){ 
print(10); 


} 
ا #include<iostream.h> 0 n‏ 
- المطلوب كتابع تابع ۷1٥م‏ لإيجاد × حيث × عدد كسري و م عدد 
float pow1(float x,int n){‏ 
float res=1;‏ 
for(int i=1;i<=n;ji++)‏ 


صحیح موجب بشکل تکراري. 


- المطلوب كتابة إجرائية W2هم‏ لإيجاد x‏ حيث »× عدد حقيقي و ۸ عدد 
صحیح موجب بشکل تکراري. res*=X;‏ 
د ق بین التابعین 1س0م و return res; 0W2‏ 


} 
void pow2(float x,int n,float &res){ 
res=1; 
EEL 
while(i<=n){ 
FéS* =X; 
i++; 


1 


۾. خا لالج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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} 
} 
void main(){‏ 
IÊ;‏ 
float x,res;‏ 
cin>>x>>n;‏ 
cout<<pow1(x,n)<<endl;‏ 
pow2(x,n,res);‏ 
cout<<res<<endl;‏ 
} 
من أنواع الفرز التي مر معنا هو الفرز بالتعويم أو الفقاعات ٣0ء‏ ماbاطuط #include<iostream.h>‏ 
و الآن نتطرف إلى نوع آخر من الفرز و هو الفرز بالاختيار اماع const int n=5;‏ 
0ء و هو عبارة عن فكرة بسيطة و هي البحث عن أصغر عنصر في struct array{‏ 
حال الترتيب التصاعدي ووضعه في بداية المصفوفة و نتابع عملية البحث int a[n];‏ 
في كل مرة عن العنصر الأصغر ثم الأصغر إلى أن نصل ترتيب عناصر } 
المصفوفة . void sortselection(array&a,int size){‏ 
عدد المقارنات في خوارزمية الاختيار هو: for(int i=0;i<n-1;i++){‏ 
int j=i; N*(N-1)/2‏ 
for(int k=i+1;jk<n;jk++)‏ 
أي إذا كان عدد عناصر الجدول(النسق)=7 هنا بحاجة إلى عدد من if(a.a[k]<a.a[j])‏ 
المقارنات هو 21 عملية مقارنة. j=k;‏ 
int temp=a.a[i];‏ 
a.a[i]=a.a[j];‏ 
a.a[j]=temp;‏ 
} 
} 
void print(array a,int n){‏ 
int i=0;‏ 
while(i<n){‏ 
cout<<a.a[i]<<",";‏ 
i++;‏ 
م 
cout<<endl;‏ 
} 
void main(){‏ 
array 455,2341}‏ 
/*for(int i=0;i<n;ji++)‏ 
a.a[i]=i+1;*/‏ 
print(a,n);‏ 
sortselection(a,n);‏ 
print(a,n);‏ 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


اكتب تابع بلغة ++ يحول من درجة حرارة على سلم فاهرنهايت إلى القيمة 
المكافئة بالدرجة المئوية وءںاوام) علماً أن قانون التحويل هو: 


5 
C= و‎ +(f-32( 


العودية (التراجعية) ع۷أءاuمr:‏ 
العودية هي عملية استدعاء التابع لنفسه عدد محلل من المرات 
العودية مكلفة زمنيا و ماديا لجهاز الحاسب حيث تعمل على استهلاك جزء 
كبير من ذاكرة الحاسب الرئيسية حيث كل استدعاء عودي يتعامل من قبل 
الذاكرة بفضاء مستقل عن الاستدعاءات العودية السابقة ٠‏ 
و نحن نعلم أن الحل التكراري يكون حلا أفضل من حيث الوقت و الذاكرة 
و لكننا نلجأً إلى الحل العودي في بعض الأحيان عندما يكون الحل التكراري 
غير واضح و من الناحية النظرية كل خوارزمية تكرارية يقابلها خوارزمية 
عودية و العكس صحيح. 
ملاحظة: يكون الحل العودي مناسبا في الرسم العودي و سنئطرق للرسم 
العودي بالتفصيل الممل؟؟؟؟. 
و المطلوب كتابة تابع بلغة ++ تابع يقوم بحساب العاملي لعدد مدخل 
0!=1 
1!=1 
2!=2*1-2 
5!=5*4*3*2*1-0 
n!=n*(n-1)*(n-2)*‏ 


في المثال العودي يمكن أن نشبه ما يحصل بالذاكرة كالتالي: 


۳ output 
First call to E 


countdown 
Num is 2 


Countdown(1); 
second call to 


countdown 
Num is 1 


Countdown(0); 
third call to 
countdown 
Num is O 


/Ino blastoff! 
/ recursive 


//call 


۾ خاګ الائ 


khaledyassinkh @gmail.com 
#include<iostream.h> 
double c(double f){ 
return (5.0/9)*(f-32); 
} 
void main(){ 
double f; 
cin>>f; 
cout<<c(f)<<endl; 


#include<iostream.h> 
int factorial(int x){ 
if)x==0( 
return (1); 
else 
return (x*factorial(x-1)); 
} 
void main(){ 
int xX; 
cin>>x; 
cout<<x<<"!="<<factorial(x)<<endl; 


#include<iostream.h> 
void countdown(int num){ 
if(num==0) 
cout<< "balstoff"; 
else 
{ 
cout<<num<<"...\n"; 
countdown(num-1); 
} 
} 
void main(){ 
countdown(2); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله جاسي اشح khaledyassinkh @gmail.com‏ 


#include<iostream.h> . المطلوب كتابة تابع عودي "لاء يقوم بجمع عددين صحيحين موجبين‎ 
int sum(int x,int y){ المطلوب كتابع تابع عودي اا" يقوم بضرب عددين صحيحين موجبين.‎ 
if(y==0) 
return X; 
else 
return 1+sum(x,y-1); 
} 
int mult(unsigned int x,unsigned int y){ 
if(y==0) 
return O; 
else 
return x+mult(x,y-1); 
} 
void main(){ 
int x,y; 
cin>>x>>y; 
cout<<sum(x,y)<<endl; 
cout<<mult(x,y)<<endl; 
} 
#include<iostream.h> اكتب تابع اء عودي لحساب مجموع عناصر نسق صحیح.‎ 
#include<conio.h> 
int sum(int a[],int n){ 


return a[0]; 
return a[n]+sum(a,n-1); 


void main(){ 

#define c5 
int mat[c]={1,20,3,4,5}; 
cout<<sum(mat,c-1); 


} 


- المطلوب كتابة تابع ۷1٥م‏ لإيجاد x‏ خی ر عذد کسر ی و غدد #include<iostream.h>‏ 
موخت نکل ودی double pow1(double x,int n){‏ 
صحیح موجب بشکل عودي. if(n>0)‏ 


ا n‏ . 
- المطلوب كتابة إجرائية ۷2٥م‏ عودية لإيجاد × حيث × عدد كسري و return x*pow1(x,n-1);‏ 
۸ عدد صحیح موجب بشکل. else‏ 

ملاحظة: (ما الفرق بين التابعين 1 سهم و 2س0wم)‏ ;1 return‏ 


1 
void pow2(double x,int n,int &res){ 
if(n>0){ 
pow2(x,n-1,res); 
res=res*x; 


۾. خاك الح اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 
} 


void main(){ 
int x,n,res; 
cin>>x>>n; 
cout<<pow1(x,n)<<endl; 
pow2(x,n,res); 
cout<<res<<endl; 


} 


#include<iostream.h> 
int f1(int n){ 
if(n<0) 
return 10; 
else 
return n/2+f1(n-1); 
void main(){ 
int res=f1(f1(5)); 
cout<<res<<endl; 
} 
#include<iostream.h> 
int f1(int n){ 
if(n>0) 
return O; 
else 
return n+f1(n+1); 
int f2(int n){ 
if(n<O)return f1(n); 
else 
return n*f1(-n); 
} 
void main(){ 
int res=f1(4); 
cout<<res<<endl; 
cout<<f1(-3)<<endl; 
cout<<f2(5)<<endl; 
cout<<f2(-4)<<endl; 
cout<<f1(f2(2))<<endl; 
#include<iostream.h> 
ÎATI=O; a. d,e,l,a,h,k, 
void main(){ b. e,l,a,h,k, 
char c[10]="khaled."; c. e,e,e,e 
if(cli]!='e') d. e,l,a,h,k, 
{ e. none of the above 
i++; 
main(); علل السبب؟‎ 
cout<<c[i]<<","; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله بسي اشح khaledyassinkh @gmail.com‏ 
1 


1 
#include<iostream.h> اكتب تابع بلغة البرمجة لعج يقوم بإيجاد القاسم المشترك الأعظم لعددين‎ 
int gcd(int x, int y){ صحيحین موجبین بشکل عودي.‎ 
if(x%y==0) لاحظ التابع 01ءع و كيفية كتابة التعليمة فى سطر واحد.‎ 
return y; 
else 
return gcd(y,x%y); 
} 
int gcd1(int x,int y){ 
return y==0?x:gcd1(y,x%y); 
} 
void main(){ 
int X,¥; 
Cin>>x>>y; 
cout<<gcd(x,y); 
} 
#include<iostream.h> اكتب بلغة ++ إجرائية عودية ٣زم بطباعة عناصر مصفوفة بشكل‎ 
void swap(int a[],int k){ معکوس.‎ 
int temp=a[k]; الخرج:‎ 
a[k]=a[k+1]; 4,1,2,3,5, 
a[k+1]=temp; 5,4,3,2,1, 
} 
void bubblesort(int *a,int n){ 
for(int i=0;i<n-1;ji++) 
for(int j=0;j<n-1;j++) 
if(a[j]>a[j+1]) 
swap(a,j); 
} 
void print(int a[],int n,int i){ 
if(i<n){ 
print(a,n,i+1); 
cout<<a[i]<<","; 
} 
} 
void main(){ 
#define n 5 
int mat[n]={5,3,2,1,4}; 
print(mat,n,O0); 
cout<<endl; 
bubblesort(mat,n); 
print(mat,n,0); 
cout<<endl; 
} 
#include<iostream.h> 
int sum(int n,int a){ 
if(n>0) 
return sum(n-1,a+n); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


else 
return a; 
} 
void main(){ 
int x=sum(5,3); 
cout<<x<<endl; 
} 
#include<iostream.h> 
int sum(int x,int y){ 
if(x>0) 
return 1+sum(x-1,y); 
else 
Feturn VY; 
} 
void main(){ 
int x=sum(5,3); 
cout<<x<<endl; 
void strange(int n){ 
if(n>O0){ 
strange(n/2); 
cout<<n%2; 
} 
} 
void main(){ 
strange(13); 
} 


. طباعة أجزاء عدد صحيح‎ . 
int strange(int n,int i){ خرج البرنامج هو:‎ 
if(n==0) 
return O; 
else 
return 
(n%10)*pow(2,i)+strange(n/10,i+1); 
} 
void main(){ 
cout<<strange(11111111,0); 


} 
#include<iostream.h> 
int f1(int n,int y){ 
if(n==0| |y==0) 
return n+y; 
else 
return n+y+f1(y-1,n-1); 
} 


void main(){ 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


2,4, 
2, 

2,4,8,16,32, 

جمیع ما سبق غير صحيح 


a. 2009‏ 
b. 200‏ 
°C. M11‏ 
d. 2012‏ 
ملاحظة: عدد مرات تنفيذ الحلقة هو 2010/3=670 و في كل مرة يتم 
زيادة العداد بمقدار 3 و منه 670*3=2010 و أول قيمة للعداد هي 1 ومنه 
قيمة العداد بعد الخروج من الحلقة هي 2010+1=2011 


الخرج: 
b‏ 


a 
cC 
d 
e 


. 6 


عدد مرات دخول الحلقة هي 5/3=2 ومنه قيمة العداد بعد الخروج من 
الحلقة هي 2*3+2=8 


الخرج: 
a. 1,2,3,4,99,‏ 
b. 2,3,4,‏ 
Cc. 2,3,4,99,‏ 


۾ خاګ الائ 


khaledyassinkh @gmail.com 
int x=f1(4,3); 
cout<<"x="<<x<<endl; 
} 
#include<iostream.h> 
int area(int n){ 
f (A==1) 
return 1; 
else 
return n+n-1+area(n-1); 
} 
void main(){ 
IM X=; 
cout<<area(x)<<endl; 
} 
#include<iostream.h> 
#include<math.h> 
f1(int n){ 
intl; 
for({i=4;i<=n*n*n;i*=4) 
cout<<sqrt(i)<< 
cout<<endl; 


Hi, 
7 


} 
void main(){ 
f1(5); 
} 
#include<iostream.h> 
#include<math.h> 
f1(int n){ 
int |, j=1; 
for(i=1ji<=n;ji+=3); 
cout<<i<<endl; 
} 
void main(){ 
f1(2010); 
} 


#include<iostream.h> 
#include<math.h> 
f1(int n){ 
int |, j=1; 
for(i=2;i<=n;ji+=3); 
cout<<i<<endl; 
} 
void main(){ 
1(5); 
} 
#include<iostream.h> 
const int n=5; 
f1(int x){ 
int i=x, a[n]={1,2,3,4,99},*p=(a+2); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله باي اشح khaledyassinkh @gmail.com‏ 
while(p!=&a[5]) . 2,3,4,‏ 


cout<<*p++<<","; 
PB . 3,4,99, 


} 
void main(){‏ 
;)15 
ا 
#include<iostream.h>‏ 
#include<math.h>‏ 
inline int f1(int n){‏ 
return n*(n+1)/2;‏ 
} 
void main(){‏ 
التابع ۴1 يقوم بحساب: cout<<f1(100);‏ 
مجموع الأعداد من 1 إلى .٠-1‏ } 
مجموع الأعداد من 1 إلى ۸-2. 
مجموع الأعداد من 1 إلى .١‏ 
. مجموع الأعداد من 2-م إلى 1. 
. مجموع قواسم العدد . 
اكتب تابع عودي يقوم بقسمة عددين صحيحين موجبين و الناتج صحيح #include<iostream.h>‏ 
بطريقة الطرح المتكرر. int mult(int x,int y){‏ 
if(x==0| | x<y)‏ 
return O;‏ 
else‏ 
return 1+mult(x-y,y);‏ 
} 
void main(){‏ 
int x,y;‏ 
cin>>x>>y;‏ 
cout<<mult(x,y)<<endl;‏ 


} 
اكتب تابع عودي لإيجاد أصغر عنصر في المصفوفة وحيدة الاتجاه. int small(int *a,int size,int value,int index){‏ 
اكتب إجرائية لإيجاد أصغر عنصر في نسق(شعاع) if(size==1)‏ 
return value;‏ 

else 


if((a[index+1]<a[index])) 
value=a[index+1] 
return small(a,size-1,value,index+1); 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله جاسي اشح khaledyassinkh @gmail.com‏ 
اكتب تابع بلغة ++ع يتحقق من كون عدد مدخل هو عدد أولي أم لا #include<iostream.h>‏ 
ملاحظة: العدد الأولي لا يقبل القسمة إلا على نفسه و الواحد. bool isprime(int x){‏ 
It I=Z:‏ 
while(x>i){‏ 
if(x%i==0)‏ 
return false;‏ 
else‏ 
if(x%i!=0)‏ 
i++;‏ 
1 
(آکک) i‏ 
return true;‏ 
} 
void main(){‏ 
IREX;‏ 
cin>>x;‏ 
if (isprime(x))‏ 
cout<<x<<"is prime"<<endl;‏ 
else‏ 
cout<<x<<"is not‏ 
prime"<<endl;‏ 


اكتب إجرائية تقوم بطباعة جميع الأعداد الأولية ضمن المجال المغلق #include<iostream.h>‏ 
[×..1] حيث × عدد أكبر من 1 يتم إدخاله من قبل المستخدم. bool isprime(int x){‏ 
ملاحظة: استفد من التابع ٣٠‏ مء المكتوب أعلاه. ;2= int‏ 
while(x>i){‏ 
if(x%i==0)‏ 
return false;‏ 
else‏ 
if(x%i!=0)‏ 
i++;‏ 
} 
if (x==i)‏ 
return true;‏ 
} 
void print(int n){‏ 
for(int i=2;i<=n;ji++)‏ 
if(isprime(i))‏ 
cout<<i<<" ";‏ 
cout<<endl;‏ 


void main(){ 
int Xx; 
cin>>x; 
print(x); 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,ل المميي. خلك بلسي الاش 
اكتب إجرائية تقوم بطباعة جميع الأعداد الأولية ضمن المجال المغلق 
[×..1] حيث × عدد أكبر من 1 يتم إدخاله من قبل المستخدم. 
ملاحظة: سوف نكتب البرنامج بأسلوب آخر. 
الخرج: 
,2,3,5,7,11 


يعرف العدد الكامل بأنه العدد الذي يساوي مجموع قواسمه ماعدا نفسه 
مثال: العدد 6 هو عدد كامل لأن مجموع قواسمه تساويه: 
1+2+3=6 
-١‏ اكتب إجرائية ٣ع‏ لارا لطباعة قواسم عدد. 
-١‏ اكتب بلغة البرمجة تابع )ععع يتحقق من كون العدد كامل أم لا. 
۲- إجرائية طباعة جميع الأعداد الكاملة الواقعة ضمن المجال المغلق 
[1..9000] مستفیدا من التابع c٥٤)‏ حصرا. 
الخرج: 
6 
,1,2,3 
28 
,1,2,4,7,14 
496 
,1,2,4,8,16,31,62,124,248 
8128 
,1,2,4,8,16,32,64,127,254,508,1016,2032,4064 


۾ خالك الاثي 


khaledyassinkh@ gmail.com 
#include<iostream.h> 
bool prime(int n){ 

bool b=0; 

if(n==2)return 1; 


for(int i=2;i<n;ji=i+1) 
if(n%i==0){ 
b=0; 
break;} 
else 
b=1; 
return b; 
} 
void print(int n){ 
EZ2: 
while(i<=n){ 
if(prime(i)) 
cout<<İ<< 


MM, 
£ 


i++; 
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} 


void main(){ 
MEXE, 
print(x); 


#include<iostream.h> 
void divider(int n){ 
for(int i=1;i<=n/2;i++) 
if(n%i==0) 
COU 
cout<<endl; 


} 


bool check(int n){ 

int sum=0; 

for(int i=1ji<=n/2ji++) 
if(n%i==0) 

sum+=i; 

if(n==sum) 
return true; 
else 
return false; 


} 


void complete(int max){ 


for(int i=1;ji<=max;i++){ 
if(check(i)){ 
cout<<i<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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divider(i);‏ 
1 


} 
} 


void main(){ 
complete(9000); 


1 


نقول عن عددین آنهما صدیقان ",م إذا کان مجموع قواسم العدد ۸ هور ۸ #include <iostream.h>‏ 
و مجموع قواسم العدد M‏ هو .۸ bool check(int n,int m){‏ 
و العددان 220و 284 مثال على ذلك. int s1=0,s2=0;‏ 
و المطلوب for(int i=1ji<=n/2ji++)‏ 
-١‏ اكتب بلغة البرمجة تابع )ءعطء يتحقق من كون العددان صديقان أم if(n%i==0)‏ 
ا s1+=i;‏ 
for(i=1;ji<=m/2;i++)‏ 
۲- اکتب برنامج لإيجاد جمیع الاعداد الصديقة ضمن المجال المغلق if (m%i==0)‏ 
[1..4000] مستفیدا من التابع )٤٥)ء‏ حصراً. أ=+2ء 
if(s1==m && s2==n)‏ 
return 1;‏ 


return O; 
} 
void search(int max){ 

Int S1=0;52=0; 

for(int n=1;jn<=max;jn++) 

for(int i=1;i<=n;ji++) 

if(check(n,i) &&n!=i) 

cout<<n<<" "<<i<<endl; 


} 


void main(){ 
search(4000); 


} 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خله بسي اشح‎ 
#include<iostream.h> اكتب تابع يتم فيه إدخال م عدد صحيح ثم يتم جمع هذه الأعداد المدخلة.‎ 
int addn(int n){ 
IMMtEI=1,5=0; 
while(i++<=n){ 
IRE X; 
cout<<"enter the number"<<i-1<<" "; 
cin>>x; 
S+=X; 
return s; 
} 
void main(){ 
IER; 
cin>>n; 
cout<<addn(n)<<endl; 


#include<iostream.h> 
void print(int n){ 
for(int i=5;i>=1;i--){ 
for(int j=i;jj>=1;j--) 
eo 
cout<<endl; 
} 
} 
void main(){ 
print(5); 
} 


#include<iostream.h> 
template <typename t> X=25 
t func(t n){ 230.5 
return n*n; ملاحظة:‎ 
} template<class ةnlتll‎ ilî template<typename t> ةnlعتll‎ 
void main(){ 1 t> 
int x; و التعليمة ۴٥ع مرا تستخدم لتعريف متحول على انه نمط من معطيات‎ 
typedef double y; معينة فمثلا - 2۴ط ۴هل مما تدل على أن ع هو نمط معطيات من نوع‎ 
X=5; > محرف. أي نستطيع الآن أن نصرح عن متحول على أنه من نمط‎ 
XëfURNê(X); مثال ;× ع أي × متحول من نمط جا‎ 
cout<<"x="<<x<<endl; 
YZ; 
255.5; 
z=func(2); 
cout<<"z="<<2<<endl; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك لمم . خل بسي اشح khaledyassinkh @gmail.com‏ 
ذكرنا في الجزء الأول من الكتاب مايلي: #include<iostream.h>‏ 
strut‏ عبارة عن بنية يمكن أن تحوي أنماط مختلفة من المعطيات (يمكن struct date{‏ 

أن نشبه بالحقيبة التي يمكن تحوي أوراق و أقلام و دفاتر و حقيبة أخرى int day;‏ 

(حقيبة بقلب حقيبة) الخ) . و البرنامج يوضح ذلك. ;]30[ char month‏ 

int year; الخرج:‎ 
1 Welcome ti syria 
struct person{ 

char name[30]; 

date Date; 
1 
struct mountain{ 

char name[30]; 

int height; 

person climber; 
} 
void main(){ 
mountain m={"Everset", 

8848, 

1 

"Edmund hillary", 

{ 

293 
"may", 
1919 

} 

} 

1 
if(m.climber.Date.year==1919) 
cout<<"welcome to syria"<<endl; 


ا 
#include<iostream.h>‏ 
struct mountain{ everset 8848‏ 
char name[30];‏ 
int height;‏ 
}info={"everset", 8848};‏ 
void sayAbout(mountain);‏ 
void main(void){‏ 
mountain k1;‏ 
K15=info;‏ 
sayAbout(k1);‏ 
} 
void sayAbout(mountain m){‏ 
cout<<m.name<<"‏ 
"<<m.height<<endl;‏ 


} 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل بسي اشح khaledyassinkh @gmail.com‏ 

#include<stdio.h> الخرج:‎ 

#include<string.h> Ali Omar 

ملاحظة: يقوم التابع رمء٣]ء‏ بأخذ و سيطين الوسيط الأول مصفوفة struct tag{‏ 
الحروف و التي تكون ذات طول مناسب لتخزين به قيمة الوسيط الثاني مع char Iname[20] ;/* last name*/‏ 
الحرف الصفري و الثاني يمثل سلسلة من الحروف يتم نسخها إلى الوسيط char fname([20];//first name‏ 
الأول مع الحرف الصفري . float rate;‏ 

و هذا التابع موجود في المكتبة string.h‏ لذلك يجب تضمينها قبل التعامل } 

struct tag my_struct; ا‎ 

int main(void){ 
strcpy(my_struct.lIname,"Omar"); 
strcpy(my_struct.fname,"Ali"); 
printf("%s ",my_struct.fname); 
printf("%s\n",my_struct.lIname); 
return O; 


#include<stdio.h> 

#include<string.h> Ali Omar 

struct tag{ Ali Omar 40 
char Iname[20] ;/* last name*/ 
char fname([20];//first name 
int age; 
float rate; 

1 

struct tag my_struct; 

void show_name(struct tag* p); 

int main(void){ 
struct tag *st_ptr; 
st_ptr=&my_struct; 
strcpy(my_struct.Iname,"Omar"); 
strcpy(my_struct.fname,"Ali"); 
printf("%s ",my_struct.fname); 
printf("%s\n ",my_struct.lIname); 
my_struct.age=40; 
show_name(st_ptr); 


return O; 

} 

void show_name(struct tag *p){ 
printf("%s ",p->fname); 
printf("%s ",p->Iname); 
printf("%d\n",p->age); 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


3612384172 
1122334678 


الخرج: 


الخرج: 
3612384172 
1122334678 
قارن التابع ٠2۲مصهء‏ مع التابع ١١2م‏ ٥ء‏ في البرنامج أعلاه. 
اختر الإجابة الصحيحة: 
الفرق بين الفرز الداخلي و الترتيب(الفرز) الخارجي هو: 
. لايوجد فرق بينهما 
الترتيب الخارجي هو الترتيب الذي يحدث خارج الذاكرة 
الرئيسية 
الترتيب الداخلى هو ما يحدث فى الذاكرة الرئيسية عندما تكون 
حجم البيانات ليست كبيرة بحيث يمكن استيعابها بالذاكرة الرئيسية 
cg .b(*) .d‏ 
کل ما سبق خاطئ 


۾ خالك الاثي 


khaledyassinkh @gmail.com 
#include<stdio.h> 
int arr[10]={3,6,1,2,3,8,4,1,7,2}; 
void bubble(int *p,int n); 
int compare(int *m,int *n); 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
printf("%d ",a[i]); 
putchar('\n'); 
} 


void main(void){ 
print(arr,10); 
bubble(arr,10); 
print(arr,10); 
} 
void bubble(int *p,int n){ 
int i,j,t; 
for(i=n-1ji>=0;i--) 
for(j=1;j<=ijj++) 
if(compare(&p[j-1],&p[j])) 
{ 
t=p[j-1]; 
pli-1]=pli]; 
pli]=t; 
} 
} 
int compare(int *m,int *n){ 
return (*m>*n); 
} 
#include<stdio.h> 
int arr[10]={3,6,1,2,3,8,4,1,7,2}; 
void bubble(int *p,int n); 
int compare(void *m,void *n); 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
printf("%d ",a[i]); 
putchar('\n'); 
} 


void main(void){ 
print(arr,10); 
bubble(arr,10); 
print(arr,10); 
} 
void bubble(int *p,int n){ 
ÎRÊ Lj 
for(i=n-1ji>=0;i--) 
for(j=1;j<=ijj++) 
if(compare(&p[j-1],&p[j1)) 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


{ 
t=p[j-1]; 
plj-1J=pli]; 
plj]=t; 
1 
} 
int compare(void *m,void *n){ 
iE ML RL 
m1=(int *)m; 
n1=(int *)n; 
return (*m1>*n1); 


#include<iostream.h> 
int main(){ 

int x=7,y=6; 

void *p1=&x,*p2=&y; 
IAC MMI, MA; 

p1=&y; p2=&x; 
m1=(int *) p1; 
m2=(int *)p2; 
*m1=*m2+3; 
*m2=*m1+5; 
cout<<*m1<<endl; 
cout<<*m2<<endl; 


return O; 
} 
#include<stdio.h> 
void main(void){ array=0012FF78 
&array[0]=0012FF78 
&array=0012FF78 
char a[5]; 
printf(" array=%p\n&array[0]=%p\n 
&array=%p\n",a,&a[0],&a); 
} 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


اممس. خل سې للح 
الخرج: 
OxO0012FF7C‏ 
0012FF7C‏ 


اكتب برنامج بلغة ++ تقوم بطباعة الأعداد الصحيحة المحصورة بين × و 
ر أي ضمن المجال المغلق [ر..»] 
مثال: 3=× و 5= أو 5=× و 3= (اجعل محتوى × تحمل الرقم الأصغر 
دوما) يتم طباعة مايلي: 

your number 3 

your number 4 

your number 5 


يو جد فى مشتشفى المواساة عدد من المرضى فى غرفة واحدة و فى هذه 
الغرفة يوجد طبيب واحد فقط و من الصعب على هذا الطبيب مراقبة هؤلاء 
المرضى جميعا في آن واحد. 

أكتب برنامج لتحذير الطبيب بوجود خطر على حياة إحدى المرضى و ذلك 
بسبب ارتفاع درجة حرارته إلى 39 و هذه الدرجة تعتبر خطرة على حياة 
المريض مما يستدعي مساعدة عاجلة من الطبيب لتخفيض درجة حرارة 
المريض 

بحيثٿ يكون هذا التحذير على شكل صوت تنبيه يخرج من جهاز الكمبيوتر. 
مع العلم أنه يتم قياس درجة حرارة المريض بفارق نصف درجة في كل 
مرحلة. 

نحن نعلم أن درجة الإنسان الطبيعية هي ٠۷‏ 

عدل البرنامج بحيث يتم إصدار صوت لمدة خمس دقائق و في حال إدخال 
أي محرف من لوحة المفاتيح من قبل الطبيب يتوقف إصدار الصوت. 


۾ خلك الائ 


khaledyassinkh @gmail.com 


#include<stdio.h> 
#include<iostream.h> 
void main(void){ 


IER: 

cout<<&x<<endl; 
char a[5]; 
printf("%p \n",&x); 


#include<iostream.h> 
void print(int x,int y){ 
do{ 
cout<<"your number 
"<<x<<endl; 
XH+; 
} 
while(x<=y); 
} 
void main(){ 
int a,b; 
cin>>a>>b; 
if(a>b){ 


b=a/b; 
a=a/b;} 


print(a,b); 
} 
#include<iostream.h> 
void watch (float t){ 
int X1; 
while (t<=40){ 
if(tS=39 
for(;:){ 


cout<<"temperature ="<<t<<endl; 


if(x%15==0){ 
cout<<x<<endl; 
break; } 
cout<<x<<endl; 
++X; 


} 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 
t=t+0.5;‏ 
} 


void main(){ 
watch(36); 
} 


ما هو عمل البرنامج: #include<iostream.h>‏ 
ه. طباعة عناصر ما تحت القطر الرئيسى void main(){‏ 
ط. طباعة عناصر ما فوق القطر الرئيسي int mat[3][3]={1,2,3,4,5,6,7,8,9};‏ 
م. طباعة عناصر ما تحت القطر الثانوي for(int i=0;i<3;i++){‏ 
0. طباعة عناصر ما فوق القطر الثانوي for(int j=0;j<3;j++)‏ 
.Dg.a .e‏ ا 

cout<<mat[i][j]<<" "; 


/ 


ما هو عمل البرنامج: #include<iostream.h>‏ 
ه. طباعة عناصر ما تحت القطر الرئيسي void main(){‏ 
ط. طباعة عناصر ما فوق القطر الرئيسى int mat[3][3]={1,2,3,4,5,6,7,8,9};‏ 
م. طباعة عناصر ما تحت القطر التانوي for(int i=0;i<3;i++){‏ 
0. طباعة عناصر ما فوق القطر الثانوي for(int j=0;j<3;j++)‏ 
.Dg.a .e‏ (ز>if)i‏ 

cout<<mat[i][j]<<" "; 


7 


۾. خاک للج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم ن. خل باي اشح 
الخرج: 
enter the value x:9‏ 
number is=9‏ 
ملاحظة: تعليمة ۴" هءء تعليمة لإدخال المعلومات من لوحة المفاتيح 
keyboard‏ 


enter the value x and y:9 10 
9 + 10-9 


ملاحظة: المؤثر >> يسمى بمؤثر الإزاحة اليساري أfأ۸ء‏ اما 
و المؤثر << يسمى بمؤثر الإزاحة إلى اليمين“ R9٣ s8!‏ . 
و التعليمة (×>>ل)=ل تعني إزاحة المتحول ل بمقدار 7 بتات(خانات). 


O0 |011‏ 00000 
8ل بعد الإزاحة إلى اليسار بسبع خانات كالتالي: 


1/00 000/0 0 


و التعليمة (لإ<<»)=×تعني إزاحة المتحول 7=× بمقدار 1 بت إلى 
اليمين: 

000O O1 |11‏ 
تصبح بعد الإزاحة قيمة 3=× كالتالي: 
00000011 


۾ خلګ الائ 


khaledyassinkh @gmail.com 


#include<stdio.h> 
void main(){ 


int x;//input 9 
printf("enter the value x:"); 
scanf("%d",&x); 
printf("number is=%d\n",x); 


#include<stdio.h> 
void main(){ 


int x,y; //input x=9 , ¥Ş=10 
printf("enter the value x and y:"); 
scanf("%d%d",&x,&y); 

printf("%d + %d= %d\n",x, y, x+y); 


} 


#include<iostream.h> 
void main(){ 


int X=7,J=1; 
cout<<(y<<x)<<endl;; 
cout<<(x>>y)<<endl; 
y=(y<<x); 

x=(x>>y); 
cout<<y<<endl; 
cout<<x<<endl; 


#include<iostream.h> 
void main(){ 


int a=5,b=6; 
cout<<(a>b)<<endl; 
cout<<!(a>b)<<endl; 
cout<<(a&8&b==a)<<endl; 
cout<<(a && b)<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خل جاسي اشح‎ 
cout<<(a&b)<<endl; 
cout<<(a^b)<<endl; 
cout<<(a | |b)<<endl; 
cout<<(a | b)<<endl; 
cout<<(a>>1)<<endl; 
cout<<(a<<2)<<endl; 
cout<<!a<<endl; 
cout<<”a<<endl; 


cout<<”b<<endl; 


#include<iostream.h> الدالة رجام تقوم بالانتظار لوقت محدد بالثواني‎ 
#include<stdio.h> 
#include<time.h> 
void delay(int sec); 
void main(){ 
int wait; 
cout<<"enter wait"; 
cin>>wait; 
delay(wait); 
cout<<"time "<<endl; 
} 
void delay(int sec){ 
int s; 
for(;:){ 
s=clock()/CLOCKS_PER_SEC; 
if(s==sec) 
break; 


} 


اكتب إجراء 0۲ءعودي لخوارزمية الفرز بالفقاعات. #include<iostream.h>‏ 
اكتب إجراء أ٣‏ آ٣م‏ عودي لطباعة عناصر نسق. void sort(int b[],int size){‏ 
اكتب إجراء 2۲2¥ هم لقراءة عناصر نسق بشكل عودي. for(int i=0;i<size-1;i++)‏ 
ملاحظة: يجب على المستخدم للبرنامج تحديد حجم النسق. if(b[il]>b[i+1]){‏ 
int temp=b|[i];‏ 
b[i]=b[i+1];‏ 
b[i+1]=temp;‏ 
1 
if(size>1)‏ 
sort(b,size-1);‏ 


} 
void readarray(int b[],int i,int size){ 
if(i<size){ 
cout<<"enter the 
b["<<i<<"]"<<endl; 
cin>>b[i]; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


درجة تعقيد التابع ۴1 هو: 


عمل التابع ۴1 هو: 


.a 


جمع عناصر مصفوفة المربعة. 


ط. جمع عناصر ما تحت القطر الرئيسى فى المصفوفة. 


الجواب الصحيح يختلف عما سبق. 


۾ خالك الاثي 


khaledyassinkh @gmail.com 
readarray(b,i+1,size); 
} 
} 
void print(int b[],int i,int size){ 
if(i<size){ 
cout<<b[i]<<","; 
print(b,i+1,size); 
} 
void main(){ 
cout<<"enter number size 
array"<<endl; 
E6; 
cih>>C: 
#define n c 
int * b=new int[n]; 
readarray(b,0,n); 
cout<<endl; 
print(b,O,n); 
sort(b,n); 
cout<<"\nafter sort"<<endl; 
print(b,O,n); 
delete[]b; 
cout<<endl; 
} 
#include<iostream.h> 
int f1(int **p,int c){ 
int res=O0; 
for(int i=0;i<c;i++) 
for(int j=0;j<ijj++) 
res=res+*(*(p+i)+j); 


return res; 
} 
void print(int **p,int n){ 
İM iyj} 
for(i=0;i<n;ji++){ 
for( j=0;j<n;j++) 


cout<<*(*(p+i)+j)<<"\t"; 
cout<<endl; 


void main(){ 
INt:E=3;} 
IME * *aj 
a=new int *[c]; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خل جاسي اشح‎ 
for(int i=0;i<c;i++) 
a[i]j=new int[c]; 
for(i=0;i<c;ji++) 
for(int j=0;j<c;j++) 
*(*(a+i)+j)=i+j; 
print(a,c); 
cout<<"f1="<<f1(a,c)<<endl; 
for(i=0;i<c;ji++) 
delete[]a[i]; 
delete[]a; 


الخرج: #include<iostream.h>‏ 
double p1(double x,unsigned int n){ 36‏ 
التابع 1م يقوم بحساب "× حيث × عدد كسري و ۸ عدد صحیيح موجب. double res=1;‏ 
while(n>0){‏ 
if(n%2!=0) res=res*x;‏ 
KEN XK‏ 
Eh/2‏ 
} 
return res;‏ 
} 
void main(){‏ 
double x=6;‏ 
int n=2;‏ 
cout<<p1(x,n)<<endl;‏ 
1 
اكتب برنامج بلغة ++ للتعامل مع الأعداد العقدية و المطلوب: #include<iostream.h>‏ 
-١‏ إجرائية لهم لقراءة عدد عقدي. #include<math.h>‏ 
۲- إجرائية(دالة) ٣م‏ لطباعة عدد عقدي. struct num{‏ 
۳- تابع(دالة) ناء لحساب مجموع عددين عقديين. float re;‏ 
-٤‏ تابع اء لحساب طرح عددين عقديین. float im;‏ 
-٥‏ تابع ام لحساب ضرب عددین عقدیین. غ 
1- تابع ۷ال لحساب قسمة عددين عقديين. void read(num&);‏ 
۷- تابع † لحساب طويلة عدد عقدي. void print(num&);‏ 
num sum(num&,num&8);‏ 
num sub(num&,num&);‏ 
num mult(num&,num&);‏ 
num div(num&,num&);‏ 
double t(num);‏ 
void main(){‏ 
num X,¥,Z;‏ 
read(x);‏ 
read(y);‏ 
cout<<"‏ 


print(x); 
cout<<endl; 
print(y); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم ن. خله بسي اشح khaledyassinkh @gmail.com‏ 


cout<<" 


z=sUum(x,y); 
cout<<"sum="; 
print(z); 

cout<<endl; 
z=sub(x,y); 
cout<<"sub=";print(z);jcout<s<endl; 
z=mult(x,y); 
cout<<"mult=";print(z);cout<<endl; 
z=div(x,¥); 
cout<<"div="; 
print(z);cout<<endl; 
cout<<t(x)<<endl; 
cout<<t(y)<<endl; 


} 


void read(num&x){ 
cin>>x.re; 
cin>>x.im; 


} 
void print(num& x){ 
cout<<x.re<<"+"<<x.im<<"l";} 


num sum(num&x,num&y){ 
num x1; 
x1.re=x.re+y.re; 
x1.im=x.im+y.im; 
return x1; 

} 

num sub(num&x,num&y){ 
num x1; 
x1.re=x.re-y.re; 
x1.im=x.im-y.im; 
return x1; 

} 

num mult(num&x,num & y){ 
num x1; 
x1.re=(x.re*y.re)-(x.im*y.im); 
x1.im=(x.re*y.im)+(y.re*x.im); 
return x1; 

} 

num div(num&x,num&y){ 
num x1,¥1,z; 
float m; 
y1.re=y.re; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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y1.im=-y.im; 
x1=mult(x,y1); 
m=pow(y.re,2)+pow(y.im,2); 
z.re=x1.re/m; 
z.im=x1.im/m; 
return Z; 

} 

double t(num x){ 
return sqrt(pow(x.re,2)+pow(x.im,2)); 


اكتب بلغة ++ع برنامج للتعامل مع التاريخ على اعتبار أن التاريخ يمثل #include<iostream.h>‏ 

بل اليوم و " الشهر و ل السنة. struct date{‏ 
= تابع rad‏ لقراءة تاریخ. int d,m,y;‏ 

إجرائية ماةل†” امم لطباعة تاريخ بالشكل ر/"/۵. 1 

تابع ع2 2d٥a۲م c٠‏ يقوم بالمقارنة بين تاريخين و يعيد القيمة date read(date);‏ 

1 في حال كان التاريخ الأول أكبر تماما من التاريخ الثاني و إلا void printdate(date);‏ 

فإنه يعيد القيمة 0. bool compare2date(date,date);‏ 

ملاحظة: int main(){‏ 
الإدخال يتم على الشكل التالي: date x,y;‏ 
إدخال اليوم ل x=read(x);‏ 
إدخال الشهر  y=read(y);‏ 
إدخال السنة ر printdate(x);‏ 
printdate(y);‏ 
cout<<"‏ 
cout<<compare2date(x,y)<<endl;‏ 


} 


date read(date x){ 
cin>>x.d; 
cin>>x.m; 
cin>>x.y; 
return xX; 
} 
void printdate(date x){ 
cout<<x.d<<"/"<<x.m<<"/"<<x.y<<end 
|; 
} 
bool compare2date(date x,date y){ 
if(x.y>Y¥.¥) 
return true; 
else 
if(x.m>y.m) 
return true; 
else 
if(x.d>y.d) 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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return 1;‏ 

else 

return false; 


اكتب برنامج بلغة ++ يقوم بتخزين بيانات طلاب السنة الأولى في كلية #include<iostream.h>‏ 
الهندسة المعلوماتية بجامعة دمشق حيث يعرف كل طالب من خلال رقم struct student{‏ 
ذاتي ۲٥ط‏ ص ںہ(لا يتكرر) و اسم ٥۳هم‏ بالإضافة إلى علامات المواد int number;‏ 
التالية: char name[30];‏ 
الرياضیات جص int prog1;‏ 
البرمجةا 1عهام 94n tar;‏ 
الإنكليزي "ع int en;‏ 
العربي 3۴ int math;‏ 
و العلامة النهائية من 100 و جميع العلامات صحيحة. float av;‏ 
ملاحظة يجب معالجة حالة تكرار إدخال رقم طالب موجود . } 
والمطلوب: void read(student a[],int n){‏ 
اقترح بنية معطيات مناسبة لتخزين بيانات الطالب. for(int i=O;i<n;i++){‏ 
-١‏ إجرائية لهعء لقراءة البيانات الخاصة بكل طالب. cin>>a[i].number;‏ 
۳ إجرائیة ٤٣٥ل‏ ںای†٣هء‏ تقوم بترتیب عناصر بیانات الطلاب for(int j=0;j<=i-1;j++){‏ 
تنازليا حسب المعدل. 


if(a[j].number==a[i].number){ إجرائية خم نوزم لطباعة اسم الطالب و رقمه و معدله.‎ -٤ 


cout<<"replay"<<endl; 
cin>>a[i].number; 


while(a[j].number==a[i].number) 


{ 
cout<<"replay"; 


cin>>a[i].number; 


} 
cin>>a[i].name; 
cin>>a[i].math; 
cin>>a[i].prog1; 
cin>>a[i].en; 
cin>>a[i].ar; 


۾. خاک الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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a[i].av=(a[i].math+a[i].prog1+a[i].en+a 
[i].ar)/4.0; 
} 
} 
void sortstudent(student a[],int n){ 
for(int i=1;i<n;ji++) 
for(int j=0;j<n-1;j++) 
if(a[j].av<a[j+1].av) 
{ 
student 
temp=a|[j]; 
alj]=a[j+1]; 
a[j+1]=temp; 
} 
1 
void printstudent(student *a,int n){ 
for(int i=0;i<n;ji++) 
cout<<af[i].number<<"\t"<<a[i].name< 
<"\t"<<a[i].av<s<endl; 


} 


void main(){ 
#define max 3 
student a[max]; 
read(a,max); 
sortstudent(a,max); 
printstudent(a,max); 
} 
#include<iostream.h> لدينا بيانات تتضمن معلومات عن موظفي كلية الهندسة المعلوماتية بجامعة‎ 
struct birthday{ دمشق تتضمن بيانات الموظف المعلومات التالية:‎ 
int d,m,y; رقم ذاتي عط ںم علما أن رقم الموظف يعطى بشكل تسلسلي حصرا(أي‎ 
2 الموظف الذي يتم إدخال بياناته أولا يأخذ الرقم 1 و الموظف الثاني الرقم‎ 
1 و هکذا....)‎ 
struct employee{ first_name Jوٺلا الاسم‎ 
int number; |asا_"2 الكنية م‎ 
char first_name([30]; تاريخ الميلاد و يتضمن اليوم ك و الشهر ص و السنة ر‎ 
char last_name([30]; الراتب إهاهء‎ 
birthday birth; : ++ و المطلوب كتابة برنامج بلغة البرمجة‎ 
double salary; اقترح بينة معطيات مناسبة لتخزين بيانات الموظف.‎ -١ 
۲ تابع لقراءة بيانات الموظف.‎ -۲ 
employee read(employee e){ إجرائية تقوم بترتيب بيانات الموظفين ترتيبا تنازليا حسب‎ 
static int i=1; الراتب.‎ 
e.number=i++; إجرائية اطا و اموق ی ا ا‎ 
cout<<"number=";cout<<e.number<< ل اللي الا ك هع الن إجراي اي اع ا‎ 


endl; 
cout<<"first_name="; 
cin>>e.first_name; 
cout<<"last_name="; 


void read(employee & e){ 
static int i=1; 
e.number=i++; 
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cin>>e.last_name; cout<<"number=";cout<<e.number<<endl; 
ee ale E a E a cout<<"first_name="; cin>>e.first_name; 
<<endl<<"\tday="; cout<<"last_name="; cin>>e.last_name; 
cin>>e.birth.d; cout<<"birthday"<<"********x*¥+***''<<endl<<"\tday="; 
cout<<endl<<"\tmonth="; cin>>e.birth.d; 
cin>>e.birth.m; cout<<endl<<"\tmonth="; cin>>e.birth.m; 
cout<<endl<<"\tyear="; cout<<endl<<"\tyear="; cin>>e.birth.y; 
cin>>e.birth.y; cout<<endl<<"salary=";cin>>e.salary; 
cout<<endl<<"salary=";jcin>>e.salary; 
return €; 
} في البرنامج(التابع) الرئيسي نكتب الاستدعاء على الشكل:‎ 
void sortemp(employee e[],int n){ read(e[i]); 
for(int i=0;i<n-1ji++) في قادم‎ C++ ملاحظة:سأشرح بالتفصيل الملفات و كيفية التعامل معها بلغة‎ 
for(int j=0;j<n-1;j++) الصفحات أو (في الجزء الثالث).‎ 


if(e[j].salary<e[j+1].salary){ 
employee 
temp=e[j]; 
elj}zêj#1]; 
e[j+1]=temp; 
ا‎ 
} 
void printemp(employee e[],int n){ 
for(int i=0;i<n;ji++){ 
cout<<"number="; 
cout<<e[i].number<<endl; 
cout<<"firsr_name="; 
cout<<e[i].first_name<<endl; 
cout<<"last_name="; 
cout<<e[i].last_name<<endl; 
cout<<"birthday="; 
cout<<e[i].birth.d<<"- 
"<<e[i].birth.m<<"-"<<e[i].birth.y<<endl; 


cout<<"salary="<<e[i].salary<<endl<<" 
"<<endl; 


} 


void main(){ 
conStint MaXxz3;} 
employee e[max];; 
for(int i=0;ji<max;i++) 
e[i]=read(e[i]); 
sortemp(e,max); 
printemp(e,max); 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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ليكن البرنامج المكتوب على يسارنا بلغة ++ و ليكن ما يلي: #include<iostream.h>‏ 
void main(){‏ 
memory address‏ اسم المتحول int x=5;‏ 
int *p=&x; Xx Ox0012FF7C‏ 


cout<<p<<endl; p Ox0012FF78 
cout<<&x<<endl<<&p<<endl; 


و المطلوب خرج البرنامج. p=NULL;‏ 
الخرج هو: cout<<p<<endl;‏ 

cout<<&p<<endl; 5 
//*p=10 error İÎطخ‎ 5 
OxO0012FF7C 
} Ox0012FF7C 
OxO0012FF78 
OxOOOOOOONO 
OxO0012FF78 


اختر الإجابة الأكثر دقة. 
ه. المؤشرات عبارة عن متحولات تحوي قيم في الذاكرة. 


ط. (*)المؤشرات عبارة عن متحولات تحوي عناوين فى الذاكرة. 
ع. المؤشرات عبارة عن متحولات تؤشر إلى عناوين بالذاكرة. 
ك. المؤشرات عبارة عن متحولات تقوم بعملية تأشير إلى محتوى 
موقع بالذاكرة. 
م. المؤشرات عبارة عن متحولات تحوي مؤشرات في الذاكرة. 
بفرض لدينا : #include<iostream.h>‏ 
Memory address‏ اسم المتحول void main(){‏ 


int *p1=new int, *p2=new int; P1 Ox0012FF7C 


Kaa, 
1; P2 0x0012FF78 


p2=p1; - : :‏ 
علما أن 1م يؤشر إلى العنوان 0×00421۴۴0 في الذاكرة و المطلوب cout<<p1<<endl;‏ 
خرج البرتامج: 


cout<<p2<<endl; 
3% الخر ج‎ 

cout<<*p1<<endl; 

cout<<*p2<<endl; 


Ox00421FFO 
Ox00421FFO 
5 

5 
Ox00421FFO 
Ox00421FFO 
99 

99 
OxO012FF7C 
OxO0012FF78 


delete(p2); 
if(p2!=NULL){ 
cout<<p1<<endl; 
cout<<p2<<endl; 
*p1=99; 
cout<<*p1<<endl; 
cout<<*p2<<endl; 
cout<<&p1<<endl; 


اختر الإجابة الصحيحة: 
ختر الإجاب 2 cout<<&p2<<endl;}‏ 


لنفرض أنه لدينا (۸۲)5| Wع"=م*‏ خم¡ فإنه عند تطبيق التعليمة 
(م)eteاde‏ فهذا يعني: 
المؤشر م أصيح لا يؤشر إلى أي عنوان في الذاكرة. 
المؤشر م أصبح يؤشر إلى العنوان صفر في الذاكرة. 
المؤشر م بقي يؤشر إلى نفس العنوان في الذاكرة. 
نے حذفا سحتری م * من الذاكرة 


(*). و ك 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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#include<iostream.h> خرج البرنامج هو:‎ 
void main(){ 
int *p1=new int, *p2=new int; . 10 
*p1=5; . 20 
B22 . None of the above 
delete(p2); 


cout<<*p1<<endl; 


#include<iostream.h> 


struct m{ a. 99,55,154 
int y; . 55,4 
1 . 15,55,99 
struct k{ . 55,99,14 


int x,y; . None of the above 
Mt 


j 
RTT 
r->t.y=99; 
F->KSD5; 
r->y=(*r).x+(*r).t.y; 
return r; 
} 
void main(){ 
KC 
k x; 
r=&x; 
f(8&x); 
cout<<r->t.y<<","; 
cout<<r->x<<","; 
cout<<r->y<<endl; 


۾. خاك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


اكتب برنامج بلغة ++ع يقوم بتعريف أنماط المعطيات و التوابع و 
الإجرائيات التي تسمح بقراءة مجموعة من الأسماء مع الأرقام الذاتية 
الخاصة بها و تخزينها في سلسلة ديناميكية المطلوب: 


2 


إجرائية ٤۲عء"‏ ال هم۲ تقوم ببناء السلسلة مرتبة تصاعديا حسب 
رقم الطالب(علما أن رقم الطالب لا يتكرر و أرقام هي أرقام 
صحيحة موجبة أكبر تماما من الصفر حصرا). 

إجرائية امل تقوم بحذف العنصر الموافق لرقم ذاتي هو دخل 
الإجرائية مع معالجة محاولة حذف رقم طالب غير موجود. 
إجرائية ٥W‏ لله تقوم بإضافة عنصر جديد (اسم ورقم 
الطا الى ال ن مالا ع ’ها ر طا ورد 
إجرائية اءاا†م ذم تقوم بطباعة عناصر السلسلة على الشكل 
التالıي .studentnumber studentnmae‏ 

تابع ءا م†unهع‏ يقوم بإعادة عدد عناصر السلسلة. 

إجرائية عااfمام۷هم‏ تقوم بنقل عناصر السلسلة مرتبة 
تصاعديا حسب الرقم الطالب إلى ملف تسلسلي هل.۴ مع 

مز اعاة خذف: العتصر المنقر ل مباشرة 


ملاحظة:التعلیمة ۲٥ط‏ ص ںہ<-م تکافیئ التعليمة ٣eطصہںہ.(م*)‏ و يجب 
تضمين م* بين قوسين لان النقطة . لها أولوية أعلى من * 


خاګ الائ 
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#include<iostream> 
#include<string> 
#include<fstream> 
using namespace std; 
typedef struct student * pstudent; 
struct student{ 
string name; 
int number; 
pstudent next; 
1 
bool search(pstudent p,int k){ 
while(p!=0){ 
if(p->number==k) 
return 1; 
p=p->next; 


return O; 


void readinsert(pstudent& p,student e){ 
(GSSNULL 7 ==0* 7) 
p=new(student); 
e.next=NULL; 
*p=e;} 
else 
if (p- 
>number>e.number){/*((*p).number>e.numb 
ê7 
e.next=p; 
p=new(student); 
*p=e; 


pstudent 
prev,temp=p; 


while ((temp!=0)&8&.(temp- 
>number<e.number)){ 
prev=temp; 
temp=temp- 
>next; 
1 
e.next=temp; 
prev->next=new 
(student); 
*prev->next=e; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 
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} 
void del(pstudent&p,student e){ 
if(p!=0) 
if(p->number==e.number){ 
pstudent pr=p; 
p=p->next; 
delete(pr); 


pstudent 
temp=p,prev; 


while ((temp!=0)&8&.(temp- 
>number<e.number)){ 
prev=temp; 
temp=temp- 


} 


prev->next=temp- 


delete(temp); 


void addnew(pstudent &p,student e){ 
if(p->number>e.number){ 
e.next=p; 
p=new student; 
*p=e; 


pstudent temp=p,prev; 
while((temp!=NULL)&&(temp- 
>number<e.number)){ 
prev=temp; 
temp=temp->next; 
1 
e.next=temp; 
prev->next=new(student); 
*prev->next=e; 


} 
void printlist(pstudent p){ 
cout<<"numberstudent"<<"\t"<<"nma 
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estudent"<<endl; 
while(p!=0){ 
cout<<p->number<<"\t"<<p- 
>name<<endl; 
p=p->next; 


} 


int counterlist(pstudent p){ 
if(p==0) 
return O; 
else 
return 1+counterlist(p->next); 


} 


void movetofile(pstudent& p){ 
pstudent temp=p; 
ofstream outfile("f.dat",ios::out); 
while(p!=NULL){ 
temp=p; 
outfile <<p->number<< 


<<Pp- 
>name<<endl; 
p=p->next; 
delete(temp); 
ا‎ 
1 
void main(){ 
#define n 3 
pstudent p=0; student e; 
for(int i=1;i<=n;i++){ 
cin>>e.number; 
while(e.number<=0){ 
cout<<"enter the 
number student>=1"<<endl; 
cin>>e.number; 
} 
cin>>e.name; 
readinsert(p,e); 
} 
printlist(p); 
cout<<"number of student 
is="<<counterlist(p)<<endl; 
cout<<"d"<<endl; 
cin>>e.number; 
if(search(p,e.number)) 
del(p,e); 
else 
cout<<"not found"; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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printlist(p); 
cout<<"add"<<endl; 
cin>>e.number; 
while(search(p,e.number)) 
{ 
cout<<"please enter the 
number"<<endl; 
cin>>e.number; 
} 
while(e.number<=0){ 
cout<<"enter the 
number student>=1"<<endl; 
cin>>e.number; 


} 


cin>>e.name; 


addnew(p,e); 

printlist(p); 

movetofile(p); 
#include<iostream.h> اكتب برنامج بلغة ++ يقوم بالتعامل مع السلاسل (لقوائم) الخطية وحيدة‎ 
#include<conio.h> الاتجاه حيث نفرض انه لدينا البنية التالية:‎ 
struct info{ struct info{ 

int num; int num; 

info * next; info * next; 
}; j 


info * insert(info*,info); و المطلوب:‎ 


-١‏ تابع ٤۲هءم|‏ لإضافة أو لحشر عنصر ضمن السلسلة. 


-٤ 


كل عنصر من السلسلة له الحقول الثالية: 2 
حيث الحقل »هم هو مؤشر إلى العنصر التالي 


تابع ٣ء٣‏ هءء للبحث عن عنصر ضمن السلسلة. 
إجرائية print‏ لطباعة عناصر السلسلة. 


num 


في السلسلة أن وجد و في حال أنه لا يؤشر إلى العنصر تالي فإن قيمته 
تساوي |ام آي: 


و يمكننا تخيل شكل السلسلة في الذاكرة كما يلي: 


info* del(info*,info); 
bool search(info*,int); 
void print(info*); 

char choice(); 


void main(){ 
info* head=NULL; 
info Vv; 
char c; 
do{ 
c=(choice()); 
switch (c){ 
case 'I': 
case 'i':{ 
cout<<"enter the 
number";jcin>>v.num; 


head=insert(head,v);break;} 
case 'D': 
case'd':{cout<<"enter the 
number";cin>>v.num; 
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سبحانك رينا لا علم لنا إلا ما علمتنا 
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head=del(head,v); 
break;} 
case 'S': 
case 's':{cout<<"enter the 
number";cin>>v.num; 


cout<<search(head,v.num)<<endl; 
break;} 
case'P': 
case 'p':{cout<<"Diplay the 
linked list"<<endl; 
print(head);break;} 
} 
while(c!='E'&&c!='e'); 
} 


info * insert(info*head,info v){ 
v.next=O; 
info* p=new info(v); 
if(head==0) 
head=p; 
else 


if(v.num<(*head).num){ 
p- 
>next=head; 
head=p; 
} 
else{ 
info 
*p1,*prev; 
p1=head; 


while((p1!=0)&&(p1->num<v.num)) 
{ 


prev=p1; 


p1=p1->next; 
} 
prev->next=p; 
p->next=p1; 
ا‎ 
return head; 


} 


info* del(info*head,info v){ 
info *p,*prev; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com 
if(head->num==v.num){ 
p=head; 
head=head->next; 
delete(p); 
1 
else{ 
p=head; 
while((p!=0)&8&(p- 
>num!=v.num)){ 
prev=p; 
p=p->next; 


} 


if((p!=0)&8&((*p).num==v.num)){ 
prev->next=p- 
>next; 
delete(p); 
ا‎ 
J 
return head; 
} 
bool search(info* head,int v){ 
info* p=head; 
while(p!=NULL){ 
if((*p).num==v) 
return true; 
p=p->next; 
} 
return false; 
} 
void print(info *head){ 
info *p=head; 
while(p!=NULL){ 
cout<<p->num<<endl; 
p=p->next; 
1 


char choice(){ 


cout<<"l:inserting to linked 
list"<<endl; 

cout<<"S:searching in linked 
list"<<endl; 

cout<<"p:printing the linked 
list"<<endl; 

cout<<"D:delete from linked 
list"<<endl; 

cout<<"E:exit"<<endl; 

char c; cin>>c; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


return C; 


باستخدام المؤشرات و بنية المكدس اكتب الإجرائيات اللازمة لتحويل عدد #include<iostream.h>‏ 
صحيح موجب أكبر من الصفر إلى ما يكافئه من عشري إلى ثنائي struct list{‏ 
متال: 8= سے 1000 int n;‏ 
list *next;‏ 
}*ph;‏ 
void push(list*&p,int x){‏ 
if(x!=0){‏ 
if(p==NULL){‏ 
p=new list;‏ 
p->n=x%2;‏ 
p->next=O0;‏ 


list *temp=new list; 
temp->n=x%2; 
temp->next=p; 
p=temp; 
} 
push(p,x/2); 
j} 
void pop(list*&p,int &res){ 
if(p!=0}{ 
list*e=p; 
p=p->next; 
res=e->n; 
delete(e); 
} 
void main(){ 
ph=0; 
int x,res; cin>>x; push(ph,x); 
while(ph!=0){ 
pop(ph,res); 
cout<<res; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


cout<<endl; 


اكتب برنامج بلغة ++ع يقوم بالتعامل مع السلاسل(القوائم) الخطية ثنائية #include<iostream.h>‏ 
الاتجاه على فرض لدينا حقل واحد للمعطيات وهو الرقم صم #include<conio.h>‏ 
يتضمن البرنامج الإجرائيات التالية: struct info{‏ 
-١‏ إجرائية ٤۲هءم|‏ لحشر عنصر ضمن السلسلة. int num;‏ 
إجرائية امل لحذف عنصر من السلسلة. info * next,*prev;‏ 
إجرائية print_up‏ لطباعة عناصر المصفوفة تصاعديا ۳ 
إجرائية س هملك_م ام لطباعة عناصر المصفوفة تنازلياً, info *pf=0,*plast=O;‏ 
void insert(info v){‏ 
v.next=0;‏ 
يمكننا تخيل شكل السلسلة ثنائية الاتجاه بالذاكرة كما يلي: EE.‏ 
كل عنصر من عناصر اللائحة يحوي الحقول التالية: info* temp=new info(v);‏ 
if(pf==0){‏ 
pf=temp;‏ 
حيث الحقل »هم هو مؤشر للعنصر التالي في السلسلة plast=temp;‏ 
و الحقل prev‏ هو مؤشر للعنصر اللاحق(السابق)في السلسلة. 


prev | num | next 


if((*pf).num>v.num){ 
temp->next=pf; 
temp->prev=0; 
pf->prev=temp; 
pf=temp; نهاية السلسلة بداية السلسلة‎ 


info * p1, B2; 
p1=pf; اختر الإجابة الصحيحة:‎ 

ه. في السلسلة الخطية وحيدة الاتجاه لا يوجد مفهوم أ" while(p1!=08&&p1->num<v.num){‏ 

ط. في السلسلة الخطية ثنائية الاتجاه لا يوجد مفهوم إأم p2=p1;‏ 

. في السلسلة الخطية الدائرية لا يوجد مفهوم |ام p1=p1->next;‏ 

0. كلمة ازم تشير إلى العنوان صفر في الذاكرة } 

if(p1!=0){ .d و‎ c(*) .e 
temp->next=p1; 
temp->prev=p2; 
p1->prev=temp; 
p2->next=temp; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خل جاسي اشح‎ 
} 
else{ 
temp->prev=p2; 
temp->next=NULL; 
p2->next=temp; 
plast=p2->next; 


} 


} 
void del(info v){ 
info *p1,*p2; 
p1=pf; 
p2=p1; 
if(pf!=0){ 
if(p1==pf&8& p1- 
>num==v.num&&p1->next==0) 
{ 
pf=0; 
plast=0; 
delete(p1); 
ا‎ 


else 
if(p1==pf&8&p1->num==v.num) 
{ 
pf=pf->next; 
pf->prev=0; 
delete(p1); 


while(p1!=08&&p1->num<v.num) 
{ 


pP2=p1; 


p1=p1->next; 
} 


if(p1==plast&&p1->num==v.num) 
{ 


plast=p1->prev; 
plast- 
>next=0; 
delete 
p1; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله بسي اشح khaledyassinkh @gmail.com‏ 


if((p1!=0)&&(p1->num==v.num)) 
{ 


p2->next=p1->next; 
p1->next->prev=p2; 
delete(p1); 

else 


cout<<"the element is not 
found"<<endl; 


} 
} 


bool search(int v){ 
info * pëpf; 
while(p!=0){ 
if(p->num==v) 
return true; 
p=p->next; 


} 
return false; 
void print_up(){ 
info*p=pf; 
while(p!=NULL){ 
cout<<p->num<<endl; 
p=p->next; 
} 
} 
void print_down(){ 
info* p=plast; 
while(p!=0){ 
cout<<p->num<<endl; 
p=p->prev; 
j 
} 
char choise(){ 
char c; 
cout<<"l:inserting to linked"<<endl; 
cout<<"S:searching in linked"<<endl; 
cout<<"U:printing the linked 
list(UP)"<<endl; 
cout<<"P:printing the linked 
list(Down)"<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,كلامتي خلګ چې اشح‎ 
cout<<"E:exit"<<endl; 
cout<<"choise="; 
cin>>c; 

return cC; 


void main(){ 
info v; char cC; 
do{ 
c=choise(); 
switch (c){ 
case'i': 
case'l':{ 
cout<<"enter 
the number"<<endl; 
cin>>v.num; 


insert(v);break; 
} 
case 'd': 
case'D':{cout<<"enter 
the number"<<endl; 
cin>>v.num; 
del(v);break; 
} 
case 's': 
case 'S':{cout<<"enter 
the number"<<endl; 
cin>>v.num; 


if(search(v.num)) 


cout<<"found"<<endl; 
else 


cout<<"not found"<<endl; 
break;} 
case 'u': 
case 
'U':{cout<<"Displaying the linked 
list(UP)"<<endl; 


print_up();break;} 
case 'p': 
case 
'P':{cout<<"displaying the linked 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


اكتب برنامج بلغة ++ يقوم بالتعامل مع السلسلة الدائرية مع تحديد بنية 
معطيات مناسبة علما أن السلسلة لها حقلي معطيات الاسم "٠‏ هم و الرقم 
hum‏ . 


كان لدى ملك ظالم طريقة مبتكرة في إعدام معارضيه إذ كان يضعهم على 
محيط دائرة و يبدأ العد بجهة عقارب الساعة تم يقوم بإعدام الشخص ذو 
العدد م تم يبدأ العد بعكس عقارب الساعة إلى أن يصل إلى الشخص ذو 
العدد م" 

و المطلوب متل المسألة باستخدام المؤشرات مع اقتراح بنية معطيات 
مناسبة. 

ملاحظة: هذه المسألة باستخدام المؤشرات تحل باستخدام السلسلة 
الدائرية(هنا لا يوجد مفهوم ااہ) 


۾. خا الاشي 


khaledyassinkh @gmail.com 


list(Down)"<<endl; 
print_down();jbreak;} 


} 
} 


while(c!='E'&&c!='e'); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


الممنس. خلجسې للش 
الخرج: 
welcome to syria‏ 
WELCOME TO SYRIA‏ 
Welcome to syria arabic‏ 
WELCOME TO SYRIA ARABIC‏ 
ملاحظة: يقوم التابع عم مه بأخذ محرف كوسيط ويعيد هذا الحرف 
الكبير الموافق له (حيث يتم تحويل الحروف من 'ه' إلى '7' إلى الحروف 
الكبيرة حسب ||ا٣۸5)‏ و إذا كان الحرف كبير أصلا فإنه يعيده نفسه. 
و التابع ٣مم‏ مه موجود في المكتبة 1.عمراء و لذلك يجب تضمينها 
قبل استخدام التابع. 
رو لدينا التابع ۲س ها الذي يأخذ كوسيط محرف و بتحقق من كونه حرف 
صغير و يرد القيمة 0 في حال كان الحرف غير صغير و هذا التابع 
موجود في المكتبة .عمراء. 


syria arabic 


طباعة عأطهrج‏ aأ٣۷ك.‏ 

طباعة هز٣‏ رك فقط. 

طباعة الحرف و فقط. 

(*) طباعة الحرف ء بشكل لا نهائى. 
الجواب الصحيح يختلف عما سبق. 


۾. خاک الاشي 


khaledyassinkh @gmail.com 
#include<iostream.h> 
#include<ctype.h> 
char * f1(char *p){ 

while(*p!='\0') 

{ 

*p=toupper(*p); 

ptt; 


} 


return pj; 
} 
void f1(char p[],int n){ 
int i=0; 
while(i<n){ 
pli]=toupper(p[i]); 
i++} 
} 
void f2(char p[],int n){ 
int i=0; 
while(i<n){ 
if(islower(p[i])) 
p[i]=toupper(p([i]); 
i++} 


} 


void main(){ 
char mat[]="welcome to syria"; 
cout<<mat<<endl; 
f1(mat); 
cout<<mat<<endl; 
char m[]="welcome to syria arabic"; 
cout<<mx<<endl; 
f1(m,23); 
cout<<mx<<endl; 
} 
#include<iostream.h> 
void main(){ 
char mat[13]="syria arabic"; 
int i=0; 
while(mat[i]!=0) 
cout<<mat[i++]; 


} 
#include<iostream.h> 
void main(){ 
char mat[13]="syria arabic"; 


while(*mat!=0) 
cout<<*mat; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


اميم . خل يې للش 

الخرج: 

„syria arabi ه. طباعة‎ 

ط. طباعة هرك فقط. 

ع. طباعة الحرف ء فقط. 

ه. طباعة الحرف و بشكل لا نهائي. 

م. (*)الجواب الصحيح يختلف عما سبق. 
ملاحظة: البرنامج لن ينفذ لأننا نحاول تغيير اسم المصفوفة باستخدام عملية 
حسابية و هذا غير مقبول بلغة ++ع و يمكن الاستعاضة عن ذلك باستخدام 
المؤشرات كالتالي مثلا. 


#include<iostream.h> 
void main(){ 
char mat[13]="syria arabic"; 
char * p=&mat[0];//or char * p=mat; 
while(*p!=0){ 
cout<<*p++; 


الخرج: 
the content in array mat is = welcome to syria arabic‏ 
the content in array a is = welcome to syria arabic‏ 
the content in array b is = welcome t‏ 
ملاحظة: 
يقوم التابع رمء٣۲ء‏ بأخذ و سيطين الوسيط الأول مصفوفة الحروف و 
التي تكون ذات طول مناسب لتخزين به قيمة الوسيط الثاني مع الحرف 
الصفري و الثاني يمثل سلسلة من الحروف يتم نسخها إلى الوسيط الأول مع 
الحرف الصفري . 
و هذا التابع موجود في المكتبة string.h‏ لذلك يجب تضمينها قبل التعامل 
معه. 
و التابع ومء ١۲ء‏ بنفس العمل الذي يقوم به التابع رمء٣]ء‏ ولكن مع فارق 
بسيط و هو أن التابع رمء٣‏ ٣ء‏ يحدد عدد الحروف الواجب نقلها(نسخها) 
من الوسيط الثاني إلى الوسيط الأول و أيضا يجب إضافة الحرف الصفري 
من قبل المبرمج في حال كان الوسيط الثالث في التابع وم٤‏ ۸٣ء‏ أصغر أو 
يساوي طول السلسلة في الوسيط الثائي. 


الخرج: 
syria arabic‏ 
syria‏ 
syria arabicsyria‏ 
syria‏ 
b= syria‏ 
syriasyria arabicsyria‏ 
يقوم التابع جء٣]ء‏ بعملية إضافة للوسيط الناني الذي هو عبارة سلسلة 
حروف إلى الوسيط الأول الدي هو عبارة عن سلسة حروف حيث يحتل 
الحرف الأول من الوسيط الثاني مكان الحرف الصفري '0)' في الوسيط 
الأول و يجب أخذ بعين الاعتبار أن يكون الوسيط الأول الذي هو عبارة 
عن مصفوفة حروف أن يحوي خانات (حجر) كافية ليتم استيعابه مع 


۾ خلك اث 


khaledyassinkh @gmail.com 
#include<iostream.h> 
void main(){ 

char mat[13]="syria arabic"; 


while(*mat!=0){ 
cout<<*mat; 
Matt; 


#include<iostream.h> 
#include<string.h> 
void main(void){ 

char mat[]="welcome to syria arabic"; 

char a[30]; 

char b[10]; 

strcpy(a,mat); 

cout<<"the content in array mat is 
='"<<mat<<endl; 

cout<<"the content in array a is 
="<<a<<endl; 

strncpy(b,mat,9); 

b[9]=0;// or b[9]="\0'; 

cout<<"the content in array b is 
="<<b<<endl; 


} 
#include<iostream.h> 
#include<string.h> 
void main(void){ 
char mat[20]="syria arabic"; 
char *a="syria"; 
char b[30]={""};//or char b[10]={'\O'}; 
cout<<mat<<endl<<a<<endl; 
strcat(mat,a); 
cout<<mat<<endl<<a<<endl; 
strncat(b,mat,5); 
cout<<"b="<<b<<endl; 


strcat(b,mat); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


الهممس. خل سې للح 
الوسيط الثاني كاملا بما فيه الحرف الصفري. 
و يقوم التابع 2٥٣٣ء‏ نفس العمل إلا أنه يحدد عدد الحروف الواجب 
إضافنها(لصقها) من من الوسيط الثاني إلى نهاية الوسيط الأول. 
و يضاف الحرف الصفري إلى السلسلة الناتجة(تلقائيا). 


الخرج: 


يقوم التابع م ٠٣ء‏ بمقارنة الوسيط الأول مع الوسيط الثاني حرفا حرفا و 
يعيد القيمة 0 في حال تساوي eT‏ 
کان ال سط رال اال آقر فن الط الى 

و التابع strn cmp‏ يقوم بنفس العمل إلا ن عملية المقارنة تشمل فقط العدد 
المحدد من الحروف فقط و لا يقوم التابع م٠٣۲]ء‏ بمقارنة الحروف التي 
تلي الحرف الصفري لإحدى السلسلتين. 


welcome 
tO 
syria 
arabic 
)هخ تتألف‎ ٥۸ مهمة التابع )ها٣ء هي تقسيم سلسلة حروف إلى عدة وحات‎ 
كل وحدة من عدة حروف و يفصل بينها فواصل (قد تكون هذه الفواصل‎ 
فراغات › حروف و علامات ترقیم» حروف...‎ 
يأخذ التابع )٣ء وسيطين الوسيط الأول هو السلسلة المراد تقسيمها و‎ 
الوسيط الثاني هو الفاصل بين وحدات السلسلة‎ 
و في البرنامج تشكل الفواصل فراغات.‎ 
و التعليمة‎ 
*p=strtok(mat," "); 
تجعل المتحول م يؤشر إلى وحدة من واحدات السلسلة جم" و يدل الوسيط‎ 
الناني أن الفصل بين كل وحة وأخرى هي فراغ.‎ 
حيث يقوم التابع )ا٣ء بالبحث عن أول وحدة مكونة من حروف يست من‎ 
حروف الفاصل (أي الفراغ) ثم يوجد الحرف الفاصل بعد أول وحدة ويضع‎ 
بدا منها الحرف الصفري '0]'. مما يساعد على تحديد الوحدة التالية التي‎ 
يبحث عنها التابع و يحتفظ التابع )ه†ء بمؤشر على الحرف التالي للوحدة‎ 
التالية في اة" و يعيد مؤشرا على بداية الوحدة التالية نفسها‎ 
و يساعد الاستدعاء المتتالي للتابع )ها٣٤ءفي تحديد الوحدات التي تتألف‎ 
منها 2 و ذلك باستخدام القيمة اال أو 0 أو '0 بدلا من الوسيط‎ 
الأول‎ 
حيث تفيد القيمة 1| ل" أنه يجب على التابع )ها٣ء متابعة عمله في تحديد‎ 


۾ خالګ الائ 


khaledyassinkh @gmail.com 


cout<<b<<endl; 


} 


#include<iostream.h> 

#include<string.h> 

void main(void){ 
char mat[20]="syria arabic"; 
char *a="syria"; 
char b[30]="hello how ara you"; 
cout<<strcmp(mat,a)<<endl; 
cout<<strcmp(a,mat)<<endl; 
cout<<strncmp(mat,a,5)<<endl; 
cout<<strncmp(mat,a,6)<<endl; 
cout<<strncmp(mat,b,3)<<endl; 
cout<<strncmp(b,mat,3)<<endl; 

Char MI= ao M2" a60, 
cout<<strncmp(m1,m2,3)<<endl; 

aj els 
cout<<strncmp(m1,m2,3)<<endl; 

MITA: 

cout<<strncmp(m1,m2,3)<<endl; 


} 


#include<iostream.h> 
#include<string.h> 
void main(){ 
char mat[30]="welcome to syria 
arabic"; 
char *p=strtok(mat," "); 
while(p!=NULL){ 
cout<<p<<endl; 
p=strtok(NULL," "); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


الوحدات اعتبارا من النقطة التي وصل إليها نتيجة الاستدعاء السابق له. 
و في حال عدم تبقي أي وحدة ضمن السلسلة هم" يعيد القيمة 0 أو 
.NULL‏ 


hello to syria jl Jاخدإلا الخرج: في حال‎ 

hello 
لاحظ أن تعليمة ماع تقرأً الحروف المدخلة حتى الوصول إلى فراغ أو‎ 
حرف سطر جديد "۸" أو حرف نهاية ملف.‎ 
syriasyriasyriahowareyou Jخدll‎ jl Jاح الخرج: في‎ 


syriasyriasyriahowa 
حيث تقوم التعليمة‎ 
cin>>setw(20)>>mat; 
بإخبار المترجم أنه لا يجب أن تزيد عدد حروف المصفوفة عن اة" عن‎ 
الحد الأقصى للمصفوفة هنا يتم قراءة 19 محرف كحد أعلى و تخزن في‎ 
لتخزين الرقم الصفري.‎ ۲١ خةم و يخصص الحرف رقم‎ 


hello to syriaJlخدإ‎ Jiح الخرج: في‎ 
hello to syria 

يسمح التابع ٥ا‏ مع.” اع بإدخال سطر كامل إلى مصفوفة بما فيها 
الفراغات 
و هذا التابع يأخذ ثلاثة وسطاء بشكل فعلي حيث يكون الوسيط الأول هي 
المصفوفة التي يتم تخزين السطر فيها و طول هذه المصفوفة و الحرف 
الذي يحدد نهاية السطر ')١'‏ . 
و ينهي التابع عمله عند قراءة الحرف '۸)' أو عند الوصول إلى نهاية 
الملف أو عند تجاوز عدد الحروف المدخلة قيمة الوسيط الثاني منقوص 
منها 1 حيث يت تخصيص الحرف الأخير لتخزين الحرف الصفري '0 
و يمكننا كتابة التعليمة 

cin.getline(mat,20,'\n'); 
بالشكل:‎ 


cin.getline(mat,20); 


khaled ہعwس الخرج: في حال كان الإدخال‎ 
khaled ne 
khaled ne 


khaledyassinkh @gmail.com 


#include<iostream.h> 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin>>setw(20)>>mat; 
cout<<mat<<endl; 


#include<iostream.h> 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin.getline(mat,20,'\n'); 
cout<<mat<<endl; 


#include<iostream.h> 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin.getline(mat, 10); 
cout<<mat<<endl; 
char *p=mat; 
while(*p!=0) 

cout<<*p++; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


الخرج: في حال كان الإدخال سwعہ khaled‏ 


الخرج: في حال كان الإدخال عأطهاa‏ aأارs‏ 
syria arabic‏ 
syria‏ 
arabic‏ 


. syria ara 
syria arab 
none of the above 


الخرج: 
wel‏ 
ome to wor‏ 
ld‏ 
ملاحظة: الفاصل هنا بين الوحدات هو الحرف ع 


ملاحظة: 

التابع ٣عاtrء‏ مهمته حساب طول سلسلة حروف ما حيث يعيد عدد 
الحروف التي تتكون منها هذه السلسلة من دون حساب الحرف الصفري 
.\O'‏ 


الخرج: 
the string has 3 space‏ 
ملاحظة: البرنامج يقوم بحساب عدد الفراغات في سلسلة حروف. 
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#include<iostream.h> 
#include<iomanip.h> 
void main(){ 
char mat[20]; 
cin.getline(mat, 10,'d'); 
cout<<mat<<endl; 
char *p=mat; 
while(*p!=0) 
cout<<*p++; 


} 

#include<iostream.h> 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin.getline(mat, 10,'d'); 
cout<<mat<<endl; 
char *p=mat; 
while(*p!=0) 

cout<<*p++; 


#include<iostream.h> 
#include<string.h> 
void main(){ 
char mat[30]="welcome to worcld"; 
char *p=strtok(mat,"c"); 
while(p!='\0'){ 
cout<<p<<endl; 
p=strtok(0,"c"); 


} 

#include<iostream.h> 

#include<string.h> 

void main(){ 

char mat[30]="welcome to syria arabic"; 
char *m="syria"; 
cout<<strlen(mat)<<endl; 
cout<<strlen(m)<<endl; 

} 

#include<iostream.h> 

#include<stdio.h> 

#include<string.h> 

typedef char * string; 

int countwithspaces(string input); 

void main(void){ 

string mat="welcome to syria arabic"; 

printf("the string has %d 

space\n",countwithspaces(mat)); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


الخرج: 
the string has 3 space‏ 
ملاحظة: لاحظ مهمة التابع عمءةمءوا 


- اكتب تابع اعا بلغة ++ يقوم بإعادة عدد خانات عدد صحيح لا يساوي 
الضفر خصرا 

- اكتب تابع ي عا عودي يقوم بنفس مهمة التابع أعاك. 

متال 123 يرد التابع 3 

0 يرد العدد 5 

1 يرد التابع العدد 6 

4- يرد اتابع 4 و هكذا دواليك 
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} 
int countwithspaces(string input){ 
int i,count=O0; 
for(i=0;i<strlen(input);ji++) 
if(input[i]==' ' ) 
count++; 
FEU OUR; 
#include<iostream.h> 
#include<stdio.h> 
#include<string.h> 
typedef char * string; 
static int isspace(char c); 
int countwithspaces(string input); 
void main(void){ 
string mat="welcome to syria arabic"; 
printf("the string has %d 
space\n",countwithspaces(mat)); 
} 
int countwithspaces(string input){ 
int i,count=O0O; 
for(i=0;i<strlen(input);ji++) 
if(isspace(input[i]) ) 
count++; 
return COUnt; 
} 
static int isspace(char c){ 
(EE) 
return 1; 
return O; 
1 
#include<iostream.h> 
int digit(long n){ 
int i=0; 
while(n!=0) 
{ 
i++; 
A=N/10; 
} 
return i; 
} 
int dig(long n){ 
if(n==0) 
return O; 
else 
return 1+dig(n/10); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل باي اشح khaledyassinkh @gmail.com‏ 


void main(){ 
long n; 
cin>>n; 
while(n==0){ 
cout<<"please enter n<>O "; 
CIRS>R, 
} 
cout<<digit(n)<<endl; 
cout<<dig(n)<<endl; 
} 
#include<iostream.h> اكتب تابع "اء عودي مهمته إعادة مجموع الأعداد الصحيحة الموجبة‎ - 
int sum(long n){ ]1..۸[ حصرا ضمن المجال المغلق‎ 
if(n==0) اكتب تابع لاء عودي مهمته جمع الأعداد الصحيحة الفردية‎ - 
return O; ]1..١[ الموجبة حصرا ضمن المجال المغلق‎ 
else 120 مثال 15=م يرد التابع مء القيمة‎ 
return n+sum(n-1); 64 ويرد التابع لله مء القيمة‎ 
int sumodd(long n){ 
(A==1( 
return 1; 
else 
if(n %2==1( 
return n+sumodd(n-1); 
else 
return sumodd(n-1); 
void main(){ 
long n; 
cin>>n; 
while(n<=0){ 
cout<<"please enter the n>O "; 
GIRS>>R); 


} 


cout<<sum(n)<<endl; 
cout<<sumodd(n)<<endl; 


} 


اكتب تابع "٥۵۵0‏ اء عودي يقوم بجمع عناصر نسق ذات الدليل الفردي حصرا #include<iostream.h>‏ 
اكتب تابع "اء عودي مهته إعادة مجموع عناصر نسق. int sum(int *a,int n){‏ 
و يطلب كتابة إجراء جص لهم لقراءة عناصر النسق و إجراء اام if(n==0)‏ 
لطباعة عناصر النسق. return O;‏ 
مثال لدينا النسق التالي: else‏ 

return a[n-1]+sum(a,n-1); 0 1 2 3 4 5 ©6‏ 
2| 13/5610 
التابع كه صنء يعيد القيمة 9 
التابع ناء يعيد القيمة 18 int sumodd(int *a,int n){‏ 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


اكتب إجراء ×2" عودي لإيجاد القيمة العظمى من بین عناصر نسق. 
اكتب إجراء أ لإيحاد أصغر عنصر في نسق. 
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return O; 
else 
if((n-1)%2==1) 
return a[n- 
1]+sumodd(a,n-1); 
else 
return sumodd(a,n-1); 
} 
void readmat(int *a,int n){ 
for(int i=0;i<n;ji++){ 
cout<<"mat["<<i<<"] "; 
cin>>a[i]; 
} 
} 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
cout<<a[i]<<","; 
cout<<endl; 
} 
void main(){ 
IE 
cin>>n; 
int * mat=new int [n]; 
readmat(mat,n); 
print(mat,n); 


cout<<"sum="<<sum(mat,n)<<endl; 
if(n!=1) 
cout<<"sumodd="<<sumodd(mat,n)<<endl; 
else 
عهںuا>يدرف يوجد دلیل‎ ال">>هn۵ا;‎ 
delete[]mat; 
} 
#include<iostream.h> 
void max(int a[],int n,int &res){ 
if(n>O0){ 
max(a,n-1,res); 
if(a[n]>res) 
res=a[n]; 
1 
} 
void min(int a[],int n,int &res){ 
if(n>O0){ 
min(a,n-1,res); 
if(a[n]<res) 
res=a[n]; 
} 


void readmat(int *a,int n){ 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله باي اشح khaledyassinkh @gmail.com‏ 

for(int i=0;i<n;ji++){ 
cout<<"mat["<<i<<"] "; 
cin>>a[i]; 


} 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
cout<<a[i]<<", 
cout<<endl; 


} 

void main(){ 
IME; 
cin>>n; 
int * mat=new int [n]; 
readmat(mat,n); 
print(mat,n); 


int res=mat[0]; 
cout<<"max="; 
max(mat,n-1,res); 
cout<<res<<endl; 
res=mat[0]; 
min(mat,n-1,res); 
cout<<"min="<<res<<endl; 
delete[]mat; 
#include<iostream.h> لدينا الطريقة التالية في التحقق من كون عدد أولي أم لا و هي كالتالي:‎ 
#include<math.h> نحن نعلم أن أي عدد زوجي عدا 2 هو عدد غير أولي و ان أي عدد يقبل‎ 
bool prime(int n){ القسمة على 2 هو غير أولي.‎ 
if(n<=1) حيث كما نعلم أن العدد الأولي لا يقبل القسمة إلا على نفسه و على الواحد‎ 
return O: مثلا تم إدخال عدد لمعرفة أن كان هذا العد أولي أم لا نبدأ بتجريب قسمة‎ 
int j=(int)sqrt(n); العدد على الاعداد من 2 إلى جذر العدد(دون الجزء العشري) المطلوب‎ 
for(int i=2;i<=jji++) معرفته إن كان اولي أم لا. فقد أثبت علماء الرياضيات أنه للتحقق‎ 
if(n%i==0) من كون العدد اولي يكفي أن نقسم العدد على الأعداد المحصورة بين 2 و‎ 
return false; جذر العدد(دون الجزء العشري)‎ 
return true; فإذا قبل القسمة على إحدى هذه الأعداد بلا باقي فإن هذا العدد غير أولي‎ 
} وإلا فهو أولي. و المطلوب كتابة تابع ٠م بلغة ++ يقوم بالتحقق من‎ 
void main(){ كون العدد أولي أم لا وفق هذه الطريقة.‎ 
int n; ۸30 الخرج: في حال‎ 
ا‎ 0, 2,3,5,7,11,13,17,19,23,29, 
for(int i=1;ji<=nji++) 
if(prime(i)) 
coutSéisé", 


} 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


ااك الممهدي. خالك يلي لاشم 
اكتب تابع ءإإمء يأخذ كوسيط قيمة المبيعات المحققة من قبل موظف 
المبيعات و يعيد التابع مبلغ العمولة و ليس الراتب المستحقة له علما 
أن نة العمولة على الشكل التالى: 

4% من قيمة المبيعات المحققة إذا كانت القيمة أقل أو يساوي من ٠٠٠٠‏ 
ليرة سورية 

6% من قيمة المبيعات المحققة فيما عدا ذلك. 


اكتب تابع ٤أعال‏ "اء عودي بلغة ++ يأخذ كوسيط عدد صحیيح و يرد 
مجموع خانات هذا العدد 

متال: ۸=123 يرد التابع 6. 

۸-4 یرد التابع 10-. 

3" يرد التابع 10. و هكذا دوالك a‏ 


اكتب تابع عودي ۷٥١‏ اعا عودي بلغة ++ يقوم بجمع خانات العدد 
التي تقبل القسمة على 2 حصرا. 

مثال: 123=م يرد التابع 2. 

1م" یرد التابع 8. 

۸1 یرد التابع 6.وهكذا دواليك ET‏ 
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#include<iostream.h> 
double sells(int n){ 
if(n==0) 
return O; 
if(n<=2000) 
return n*0.04; 
else 
return n*0.06; 
} 
void main(){ 
int n; 
cin>>n; 
cout<<sells(n)<<" sp"<<endl; 
} 
#include<iostream.h> 
int sumdigit(int n){ 
if(n==0) 
return O; 
else 
return 
n%10+sumdigit(n/10); 
} 
void main(){ 
IE 
ciNS>>A} 
cout<<sumdigit(n)<<endl; 


#include<iostream.h> 
int digiteven(int n){ 


return O; 


if((N%10)(%2==0) 
return 
n%10+digiteven(n/10); 
else 
return 
digiteven(n/10); 
} 
void main(){ 
int n; 
cin>>n; 
cout<<digiteven(n)<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك لمم . خل بسي اشح 
البرمجة غرضية الزتوج4 :object oriented program ming(0OP)‏ 
تهدف البرمجة غرضية التوجه إلى تضمين المعطيات (الصفات 
)attributes‏ و التوابع و الإجرائيات (الأفعال ١٣رهم‏ ط)أو عمليات 
rati0ص‌مە‏ ضمن مکونات تسمی الصفوف 5عءءهاع. 
يطلق على المعطيات الخاصة بصف بالمعطيات الأعضاء كما عص 
ةل و على التوابع الخاصة بهذا الصف بالتوابع الأعضاء 
member functions‏ 
أو الطرائق ماهم و لاستخدام هذا الصف نشتق منه أغراض ءاءعزطه. 
إذاً يمكننا الآن أن نقول أن الصفوف تساعد على نمذجة الأغراض التي لها عدة 
صفات و التي یتم تمثيلھا علڪ شكJ‏ معطيات Îعضlء members data‏ 
كما يمكنها أن تقوم بتنفيذ عدة أفعال (ء٣هااههمم)‏ أو عمليات 
operations‏ 
و التي يتم تمثيلھا عل شكJ member function ءlضعeİ gli‏ 
و يتم عريف الصفوف بلغة ++ بالكلمة المحجوزة ووهاع و نستخدم اسم 
الصف لتعريف الأغراض التي تنتمي إليه أما الطرائق sلهطام"‏ فيتم 
التعامل معها من خلال عملية الاستدعاء من قبل الغرض المشتق منه. 
أفضل مثال نبداً به هو صف للتعامل مع التاريخ ماه. 
الخرج: 
1-1-1 
3-5-3 
3 
3-1-1 
الشرح: 
يبدأ تعريف الصف مهل بالكلمة المحجوزة ءءهاع و يتم تحديد جسم 
الصف بالقوسين ;[) حيث ينتهي تعريف الصف بالفاصلة المنقوطة ; 
يتضمن الصف المعطيات الأعضاء التالية year ,monthe,day‏ 
و التوابع الأعضاء التالية: da‏ 
,„setday,setmonthe,setyear,getday,getmonthe,getyear‏ 
„print‏ 
تدعى الأسماء عiاطںم‏ و private‏ و rotectedم‏ بمحددات الوصول 
إلى المعطيات والتوابع الأعضاء المتعلقة بالصف و تنتهي أسماء المحددات 
دائما بنقطتین : مثال (:اطام) و ينتهي مفعول محدد ما بورود اسم محدد 
اخر. 
و جميع المعطيات و التوابع الأعضاء الوارة بعد المحدد عاج۷أم لا يمكن 
الوصول إليها إلا من خلال التوابع الأعضاء أو التوابع الأصدقاء 
و لاحظ استخدام العملية الثنائية لتحديد مجال الرؤية :: و ذلك للتوابع 
الأعضاء في الصف مهل و الواردة بعد تعريف الصف حيث يسبق اسم 
التابع ذكر اسم الصف متبوعا بالعملية الثنائية لتحديد مجال الرؤية و على 
اعتبار أنه يمكن أن يكون لعدة توابع أعضاء من صفوف مختلفة الاسم و 
الترويسة نفسها لذلك تقوم العملية الثنائية لتحديد مجال لرؤية بالربط ما بين 
اسم التابع العضو و الصف بحيث يحصل على تحديد وحيد للتوابع الأعضاء 
المرتبطة بصف محدد. و إذا كان التابع ٥ماما‏ فليس هناك ضرورة لكتابة 
جسم التابع خارج بنية الصف و أنما يتم ذكرها داخله و كمثال التابع 
.getday‏ 
إعطاء قيم ابتدائية لأغراض صف من خلال البوانى ءاconstructo:‏ 
عند إنشاء غرض من صف يمكن لمعطياته أن تأخذ قيم ابتدائية بواسطة 
تابع يدعى بالباني مرتبط بهذا الصف و يحمل باني الصف نفس اسم الصف 
و لا يُحدد نمط القيمة المعادة منه و يتم استدعاؤه أتوماتيكيا عند انشاء أي 
غرض من الصف. 
و يوجد ثلاثة أنواع من البواني : 
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#include "iostream.h" 
class date{ 
private:int day,monthe,year; 
public: 
date(int=1,int=1,int=2011); 
date(date&); 
void setday(int); 
void setmonthe(int); 
void setyear(int); 
int getday()const{return day;} 
int getmonthe()const{return monthe;} 
int getyear()const{return year;} 
void print()const; 
~date(){} 
5 
date::date(int d,int m,int y){ 
setday(d); setmonthe(m);setyear(y); 
ا‎ 
date::date(date& da){ 
setday(da.day+2); 
setmonthe(da.monthe); 
setyear(da.year); 
} 
void date::setday(int d){day=d;} 
void date::setmonthe(int m){monthe=m;} 
void date::setyear(int y){year=y;} 
void date::print()const{ 
cout<<day<<"-"<<monthe<< 
} 
void main(){ 
int d,m,y; 
date d1,d2(1,1,2012),d3(d1);; 
// cin>>d>>m>>y; 
d=3; 
M55; 
¥=2013; 
d2.setday(d); 
d2.setmonthe(m); 
d2.setyear(y); 
d1.print(); 
d2.print(); 
cout<<d2.getday()<<endl; 
d3.print(); 


<<year<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل بسي اشح 
-١‏ الباني الافتراضي 
-١‏ الباني ذات الوسطاء 
۳- الباني الناسخ 
و يتضمن مثال صف آلتاريخ على البواني التالية: 
ت باني ذو وسطاء(وسطاء ذات قیم افتراضية) 
date(int=1,int=1,int=2011);‏ 


باني ناسخ 


date(date&); 
كيفية الوصول إلى أعضاء الصف:‎ 
تشابه العمليات المستخدمة للوصول إلى اعضاء صف تلك العمليات‎ 
المستخدمة للوصول إلى حقول السجلات و بالتالي للوصول إلى اعضاء‎ 
)- الصف باستخدام العملية (.) مصحوبة باسم الغرض أو باستخدام العملية‎ 
مع اسم الغرض المؤشر.‎ <( 
و يجب ضبط عملية الوصول إلى المعطيات و خاصة المعطيات الخاصة‎ 
بشکل جید من خلال توابع ٤٥ع و توابع ٤٥ء فعلى سبيل المثال للسماح‎ 
بقراءة قيمة من المعطيات الخاصة نقوم بكتابة التابع العضو من نوع هع‎ 
المناسب للقيام بذلك و للسماح بتعديل قيمة من المعطيات الخاصة نقوم‎ 
بكتابة التابع العضو من النوع ع المناسب للقيام بهذه المهمة.‎ 
و يتضمن مثال صف التاريخ مدل توابع الوصول التالية:‎ 
توابع ال أعع:‎ -۳ 
int getday()const{return day;} 
int getmonthe()const{return monthe;} 
int getyear()const{return year;} 
توابع ال اعك:‎ -٤ 
void date::setday(int d){day=d;} 
void date::setmonthe(int m){monthe=m;} 
void date::setyear(int y){year=y;} 


و يمكننا استدعاء الطرائق لطاع" من خلال مجموعة من الأغراض 


ملاحظة هامة:إذا لم يذكر اسم محدد الصفوف قبل ذكر الأعضاء فهذه 
الأعضاء هي عاة۷آ۲م ضمناً. 
الخرج: 


khaledyassinkh @gmail.com 


#include<iostream.h> 
class X{ 


void print(){ 
cout<<y<<endl;} 
int y; 


x(){ y=99;} 
void f(x t){ 
t.print(); 
} 
ر‎ 
void main(){ 
X1 
LR; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خله باي اشح khaledyassinkh @gmail.com‏ 


#include<iostream.h> 

class work{ 

public: 
int Xx; 
void print(){ 

cout<<x<<endl;} 

اعد كتابة الصف )۲مس بحيث يتم تعريف العضو × على أنه عضو خاص 1 

و استخدم الباني لأعطاء قيم ابتدائية له من خلال الباني و من خلال تابع void main(void){‏ 
عضو في الصف )٣0س‏ . work W;‏ 
work *wp=&w;‏ 
work &wref=w;‏ 
w.x=99;‏ 
w.print();‏ 
wref.x=wref.x-9;‏ 
w.print();‏ 
wref.print();‏ 
Wp->x=5;‏ 
w.print();‏ 
wp->print();‏ 

} 

ملاحظة هامة:إذا لم يذكر اسم محدد الصفوف قبل ذكر الأعضاء فهذه #include<iostream.h>‏ 

الأعضاء هي ارام ضمناً. class work{‏ 

int x; الخرج:‎ 

public: 

work(int y){x=y;} 


void print(){ 
cout<<x<<endl;} 
void modifity(int y){ 
x=y;} 
1 
void main(void){ 
int y=99; 
work w(y); 
work *wp=&w; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


work &wref=w; 
y=y-9; 
w.print(); 


w.print(); 
wref.print(); 
wp->mo difity(y); 


w.print(); 
wref.modifity(5); 
w.print(); 


#include<iostream.h> 
class A{ public:A(){cout<<"A ";} 
PA GOUTSE AE 
class B:public A{ 
public:B(){cout<<"B ";} 
“B(){cout<<"”B";} 
} 
class C:public B{ 
public:C(){cout<<"C ";} 
"EGOS E 
void main(){ 
(e 
cout<<endl;} 


#include<iostream.h> 
class A{ public:A(){cout<<"A ";} 
“A(ceoutsé"™ AH: AB C^CTB^A 
class B:public A{ 
public:B(){cout<<"B ";} 
^B(){cout<<"”B";} 
j 
class C:public B{ 
public:C(){cout<<"C ";} 
PE){GoOUES PC; FE 
void main(){ 
{CGF 
cout<<endl;} 


#include <iostream.h> 
class array 100,300, 
1,2,3,4,5, 
private: 
ih *aã; 
int dim,i; 
public: 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خله بسي للح‎ 
array() 
{ 
a=new int[2]; 
dim=2; 
i=0; 
} 
array(int |) 
{ 
a=new int[l]; 
dim=l; 
i=0; 
} 
void add(int d) 
{ 
if (i>=dim) 
{ 
cout<<"array boud exceed"; 
i=0; 
} 
a[i]=d; 


void print() 

{ 

for (int j=0;j<dim;j++) 
cout<<a[j]<<","; 
cout<<endl; 

} 

1 

void main() 

{ 

array a1,a2(5); 
a1.add(100); 
a1.add(300); 
a1.print(); 
a2.add(1); 
a2.add(2); 
a2.add(3); 
a2.add(4); 
a2.add(5); 
a2.print(); 

} 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك لمم . خله جاسي اشح‎ 
#include "iostream" الخرج:‎ 
using namespace std; 
class index 
{ 
private: 
int count; 
public: 
index() 
{ 
count=0; 
} 
void operator++() 
{ 


++COUNt; 


} 


void showdata() 


cout<<count<<endl; 


void main() 
{ 
index c; 
êoUt<<"1 6=" 
c.showdata(); 
++C; 
coUt<<"2 e2" 
c.showdata(); 
++Cj; 
cout<<"3 =": 
c.showdata(); 
1 
#include<iostream.h> 
class test{ 
public:test(int=0); 
void print()const; 

private: 

int Xx; 
j 
test::test(int value):x(value){} 
void test::print()const{ 


colts<xS<","; 
cout<<this->x<<","; 
cout<<(*this).x<<endl; 


} 


void main(){ 


test t(5); 
t.print(); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 


#include<iostream.h> 
class test{ 
public: 
test(){x=y=5;} 
int x,y; 


void print()const; 


1 
class op:public test{ 


void test::print()const{ 
cout<<x<<" "<<y<<endl; 
} 
void main(){ 
op t; 
t.X=t.y+T.X; 
t.y=t.X+t.Y; 
t.print(); 
} 
#include<iostream.h> 
class k{ 
public: 
IRE XV} 
void f(int n,int m){ 
Xj 
y=m; 


1 
print(){cout<<X; 
cout<<","<<y<<endl;} 


5 


void main(){ 
k* p1=new k; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خله بسي اشح‎ 
k* p2=new kK; 
p2=p1; 
p1->f(5,10); 
p2->print(); 


#include<iostream.h> 
class k{ 
int X,¥; 
public: 
void f(int n,int m){ 
Xf 
ym; 


} 
print(){cout<<X; 
cout<<","<<y<<endl;} 


} 


void main(){ 
k* p1=new k; 
k* p2=new kK; 
p2=p1; 
p1->f(5,10); 
p2->print(); 


} 
#include<iostream.h> 
#include<conio.h> 
class t{ 
public: 
IRE XY} 
void f(int yy){ 
X=y=Yy; 
ا‎ 
print(); 


1 
t::print(){ 
cout<<x<<","<<y<<endl; 


} 


void main(){ 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


,لك امم . خل جاسي اشح khaledyassinkh @gmail.com‏ 
tf,‏ 

t*e; 
e=&r; 
r.f(9); 
e->f(55); 
e->x=99; 
(Fe XS77; 
r.print(); 
getch(); 


#include<iostream.h> 
class aa{ 
private: 

int a,b; 
public: 


void f(int x,int y) {a=x; b=y;} 
int f1()const {return a*b;} 


1 


void main(){ 
aa p1; 
p1.f(10,250); 
cout<<p1.f1()<<endl; 
} 
#include<iostream.h> 
class A{ A default constructor 
public: B default constructor 
A(){cout<<"A default constructor \n";} 
A(A&){cout<<"A copy constructor A default constructor 
AF B default constructor 
~A(){cout<<"A destructor \n";}}; C default constructor 
class B:public A{ B destructor 
public: A destructor 
B(){cout<<"B default 
constructor \n";} 
B(B&){cout<<"B copy 
constructor \n";} 
^”B(){cout<<"B destructor \n";}}; 


class C{ 
public: 
C(){cout<<"C default 
constructor \n";} 


C(C&){cout<<"C cOpYy 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خل جاسي للح‎ 
constructor \n";} 
~“C(){cout<<"C 
destructor \n";} 
private: 
B x2; 
1 
void main(){ 
B b; cout<<endl; 
C* cp=new C;} 


#include<iostream.h> 
class A{ للصفوف سيكون بالجزء الثالث.‎ 
public: 
A(){cout<<"A default constructor \n";} 
A(A8.){cout<<"A copy constructor 
ا‎ 
~A(){cout<<"A destructor \n";}}; 
class B:public A{ 
public: 
B(){cout<<"B default 
constructor \n";} 
B(B&){cout<<"B copy 
constructor \n";} 
~B(){cout<<"B destructor \n";}}; 


class C{ 
public: 
C(){cout<<"C default 
constructor \n";} 
C(C&){cout<<"C cOPpYy 
constructor \n";} 
“C(J{cout<s<"C 
destructor \n";} 
private: A x1; 
B X2; 
1 
B fun(C *p,B b); 


void main(){ 
B b; cout<<endl; 
C* cp=new C; 
cout<<"\n before 
call\n"<<endl; 
b=fun(cp,b); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك رينا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خل جاسي اشح‎ 
B fun(C *p,B b){ 
cout<<"\nin fun 


\n"<<endl; 
A a; cout<<endl; B 


bb(b); 

cout<<endl; 
delete(p); 
cout<<endl; 
return bb; 


"الخسارة الكبرى هى ما يموت فينا و نحن أحياء" 


(اللهم صلي وسلم على سيدنا محمد و على آله وصحبه أجمعين) 


ناديت باسمك يا إلهي ضارعا إن لم تجبني فمن يجيب بكائي 
أنت الكريم فلا تدعني تائها فلقد عييت من البعماد النائي 
مالي سوى أعتاب جودك موئلا فلئن رددت فمن سواك رجائي 


دع الایام تفعل ما تشَاء وَطب تسا إا حکم القضاءٌ 
ولا تَجْرع إحادثة الليالي قما لِحَوّادث الذنيا بقاءُ 
(من شعر الإمام الشافعي رحمه اللّه) 


(کل ابن أنثى و إن طالت سلامتة يوماً على آلة حدباء محمول) 


(إن أكبر معركة يخوضها الإنسان هي المعركة التي يغير فيها بعض عاداته و سلوكياته) 


۾. خاك اشيج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


